On Sun, Nov 14, 2010 at 10:29 PM, Mitani <[email protected]> wrote:
>
>
>> -----Original Message-----
>> From: Garrett Cooper [mailto:[email protected]]
>> Sent: Monday, November 15, 2010 2:20 PM
>> To: Mitani
>> Cc: [email protected]; 當座 健市
>> Subject: Re: [LTP] Realtime test failure
>>
>> 2010/11/14 Mitani <[email protected]>:
>> >> -----Original Message-----
>> >> From: Garrett Cooper [mailto:[email protected]]
>> >> Sent: Monday, November 15, 2010 12:03 PM
>> >> To: Mitani
>> >> Subject: Re: [LTP] Realtime test failure
>> >>
>> >> On Sun, Nov 14, 2010 at 6:54 PM, Mitani <[email protected]> wrote:
>> >> > Hi,
>> >> >
>> >> > "realtime" build failed in my system with git "ltp-f388d33.tar.gz":
>> >> > ------------<RHEL4.8 - x86>
>> >> > make[2]: Entering directory
>> >> `/home/LTP/ltp-dev-20101112/testcases/realtime'
>> >> > make -C lib -f
>> >> "/home/LTP/ltp-dev-20101112/testcases/realtime/lib/Makefile"
>> >> > all
>> >> > make[3]: Entering directory
>> >> > `/home/LTP/ltp-dev-20101112/testcases/realtime/lib'
>> >> > gcc -g -O2 -g -O2 -fno-strict-aliasing -pipe -Wall -D_GNU_SOURCE
>> >> > -I/home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include
>> >> > -I../../../include -I../../../include  -c -o librttest.o
>> librttest.c
>> >> > In file included from librttest.c:43:
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include/librtte
>> >> st.h: In
>> >> > function `atomic_add':
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include/librtte
>> >> st.h:119
>> >> > : warning: implicit declaration of function `__sync_add_and_fetch'
>> >> > gcc -g -O2 -g -O2 -fno-strict-aliasing -pipe -Wall -D_GNU_SOURCE
>> >> > -I/home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include
>> >> > -I../../../include -I../../../include  -c -o libstats.o libstats.c
>> >> > In file included from libstats.c:47:
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include/librtte
>> >> st.h: In
>> >> > function `atomic_add':
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include/librtte
>> >> st.h:119
>> >> > : warning: implicit declaration of function `__sync_add_and_fetch'
>> >> > if [ -z "librttest.o libstats.o" ] ; then \
>> >> >        echo "Cowardly refusing to create empty archive"; \
>> >> >        exit 1; \
>> >> > fi
>> >> > ar -rc "librealtime.a" librttest.o libstats.o
>> >> > ranlib "librealtime.a"
>> >> > make[3]: Leaving directory
>> >> > `/home/LTP/ltp-dev-20101112/testcases/realtime/lib'
>> >> > make[3]: Entering directory
>> >> > `/home/LTP/ltp-dev-20101112/testcases/realtime/func'
>> >> > make[4]: Entering directory
>> >> >
>> `/home/LTP/ltp-dev-20101112/testcases/realtime/func/async_handler'
>> >> > gcc -g -O2 -g -O2 -fno-strict-aliasing -pipe -Wall -D_GNU_SOURCE
>> >> > -I/home/LTP/ltp-dev-20101112/testcases/realtime/include
>> >> > -I../../../../include -I../../../../include
>> >> > -L/home/LTP/ltp-dev-20101112/testcases/realtime/lib
>> >> -L../../../../lib
>> >> > async_handler.c   -lrealtime -lpthread -lrt -lm -o async_handler
>> >> > In file included from async_handler.c:42:
>> >> >
>> /home/LTP/ltp-dev-20101112/testcases/realtime/include/librttest.h:
>> >> In
>> >> > function `atomic_add':
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/include/librttest.h:11
>> >> 9:
>> >> > warning: implicit declaration of function `__sync_add_and_fetch'
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/lib/librealtime.a(libr
>> >> ttest.o)
>> >> > (.text+0x1a7): In function `create_thread':
>> >> >
>> >>
>> /home/LTP/ltp-dev-20101112/testcases/realtime/lib/../include/librtte
>> >> st.h:119
>> >> > : undefined reference to `__sync_add_and_fetch'
>> >> > collect2: ld returned 1 exit status
>> >> > make[4]: *** [async_handler] Error 1
>> >> > make[4]: Leaving directory
>> >> >
>> `/home/LTP/ltp-dev-20101112/testcases/realtime/func/async_handler'
>> >> > make[3]: *** [all] Error 2
>> >> > make[3]: Leaving directory
>> >> > `/home/LTP/ltp-dev-20101112/testcases/realtime/func'
>> >> > make[2]: *** [all] Error 2
>> >> > make[2]: Leaving directory
>> >> `/home/LTP/ltp-dev-20101112/testcases/realtime'
>> >> > make[1]: *** [all] Error 2
>> >> > make[1]: Leaving directory `/home/LTP/ltp-dev-20101112/testcases'
>> >> > make: *** [testcases-all] Error 2
>> >> > ------------
>> >> >
>> >> > "realtime" build failed in:
>> >> > ------------
>> >> > RHEL4.8 -- x86, x86_64, ia64
>> >> > RHEL5.4 -- x86
>> >> > ------------
>> >> >
>> >> > "realtime" build succeeded in:
>> >> > ------------
>> >> > RHEL5.4 -- x86_64, ia64
>> >> > ------------
>> >> >
>> >> > It is caused by "__sync_add_and_fetch".
>> >> >
>> >> > In following URL, "__sync_add_and_fetch" is "built-in functions for
>> >> > atomic memory access". And It is provided in "gcc":
>> >>
>> >   http://gcc.gnu.org/onlinedocs/gcc-4.4.0/gcc/Atomic-Builtins.html
>> >> >
>> >> > There is "__sync_add_and_fetch" in gcc4.1.2 (It is the gcc of RHEL5.1
>> >> -
>> >> > RHEL5.4).
>> >> > And there is not "__sync_add_and_fetch" in gcc3.4.6 (It is the gcc
>> of
>> >> > RHEL4.8)
>> >> >
>> >> > In addition, "__sync_add_and_fetch" is for 64 bit environment.
>> >> >
>> >> >
>> >>
>> http://stackoverflow.com/questions/130740/link-error-when-compiling-
>> >> gcc-atom
>> >> > ic-operation-in-32-bit-mode
>> >> >
>> >> >   http://gcc.gnu.org/wiki/Atomic
>> >> >
>> >> > Perhaps, the judgment that "realtime" must be built or not depends
>> on
>> >> > gcc's version (> 4.0) and 64 bits environment, I think.
>> >>
>> >> Could you please attach your testcases/realtime/config.log and
>> >> testcases/realtime/include/realtime_config.h ?
>> >> Thanks,
>> >> -Garrett
>> >
>> >
>> > I understood.
>> > Thank you and sorry for my insufficient information.
>> >
>> > I attach following files:
>> >   - config.log        (RHEL4.8-x86)
>> >   - realtime_config.h (RHEL4.8-x86)
>> >   - config.log        (RHEL5.5-x86)
>> >   - realtime_config.h (RHEL5.5-x86)
>>
>>     Could you please try compiling the following C sources in both
>> scenarios?
>> Thanks,
>> -Garrett
>>
>> #ifndef _GNU_SOURCE
>> #define _GNU_SOURCE
>> #endif
>> #include <stdlib.h>
>> int main(void) {
>>         char *c;
>>         return __sync_add_and_fetch(c, 1);
>> }
>
>
> I was going to compile the sent source in RHEL4.8/5.5-x86, but failed.
>
> ------------<RHEL4.8-x86>
> [r...@rhel48-ltp-x86 async_handler]# cat realtime-test.c
> #ifndef _GNU_SOURCE
> #define _GNU_SOURCE
> #endif
> #include <stdlib.h>
> int main(void) {
>        char *c;
>        return __sync_add_and_fetch(c, 1); }
>
> [r...@rhel48-ltp-x86 async_handler]# gcc realtime-test.c -o realtime-test
> /tmp/cciHVx8b.o(.text+0x25): In function `main':
> : undefined reference to `__sync_add_and_fetch'
> collect2: ld returned 1 exit status
> [r...@rhel48-ltp-x86 async_handler]#
> [r...@rhel48-ltp-x86 async_handler]# gcc -g -O2 -g -O2 -fno-strict-aliasing 
> -pipe -Wall -D
> _GNU_SOURCE  -I/home/LTP/ltp-dev-20101112/testcases/realtime/include 
> -I../../../../include
>  -I../../../../include   -L/home/LTP/ltp-dev-20101112/testcases/realtime/lib 
> -L../../../..
> /lib  realtime-test.c   -lrealtime -lpthread -lrt -lm -o realtime-test
> realtime-test.c: In function `main':
> realtime-test.c:7: warning: implicit declaration of function 
> `__sync_add_and_fetch'
> realtime-test.c:6: warning: 'c' might be used uninitialized in this function
> /tmp/ccIDckLk.o(.text+0x10): In function `main':
> /home/LTP/ltp-dev-20101112/testcases/realtime/func/async_handler/realtime-test.c:7:
>  undefined reference to `__sync_add_and_fetch'
> collect2: ld returned 1 exit status
> [r...@rhel48-ltp-x86 async_handler]#
> ------------
>
> ------------<RHEL5.5-x86>
> [r...@rhel55-ltp-x86 async_handler]# cat realtime-test.c
> #ifndef _GNU_SOURCE
> #define _GNU_SOURCE
> #endif
> #include <stdlib.h>
> int main(void) {
>        char *c;
>        return __sync_add_and_fetch(c, 1); }
>
> [r...@rhel55-ltp-x86 async_handler]# gcc realtime-test.c -o realtime-test
> /tmp/ccK8hmPs.o: In function `main':
> realtime-test.c:(.text+0x20): undefined reference to `__sync_add_and_fetch_1'
> collect2: ld returned 1 exit status
> [r...@rhel55-ltp-x86 async_handler]# gcc -g -O2 -g -O2 -fno-strict-aliasing 
> -pipe -Wall -D
> _GNU_SOURCE  -I/home/LTP/ltp-dev-20101112/testcases/realtime/include 
> -I../../../../include
>  -I../../../../include   -L/home/LTP/ltp-dev-20101112/testcases/realtime/lib 
> -L../../../..
> /lib  realtime-test.c   -lrealtime -lpthread -lrt -lm -o realtime-test
> realtime-test.c: In function 'main':
> realtime-test.c:7: warning: 'c' is used uninitialized in this function
> /tmp/ccKUnocB.o: In function `main':
> /home/LTP/ltp-dev-20101112/testcases/realtime/func/async_handler/realtime-test.c:7:
>  undefined reference to `__sync_add_and_fetch_1'
> collect2: ld returned 1 exit status
> [r...@rhel55-ltp-x86 async_handler]#

    Not sure why but it incorrectly passed on your machine:

configure:5186: checking Checking for __sync_add_and_fetch gcc builtin function
configure:5216: gcc -c -g -O2  conftest.c >&5
configure:5222: $? = 0

23 AC_MSG_CHECKING([Checking for __sync_add_and_fetch gcc builtin function])
24 AC_TRY_COMPILE([
25 #ifndef _GNU_SOURCE
26 #define _GNU_SOURCE
27 #endif
28 #include <stdlib.h>],[int main(void) {
29         char *c;
30         return __sync_add_and_fetch(c, 1);
31 }],[has___sync_add_and_fetch=yes])
32 if test "x$has___sync_add_and_fetch" = xyes; then
33         AC_DEFINE(HAVE___SYNC_ADD_AND_FETCH,1,[Define to 1 if you
have the __   sync_add_and_fetch gcc builtin function])
34         AC_MSG_RESULT(yes)
35 else
36         AC_MSG_RESULT(no)
37 fi

    Whereas it didn't on mine:

248 configure:4777: checking Checking for __sync_add_and_fetch gcc
builtin funct    ion
249 configure:4797: gcc -c -g -O2  conftest.c >&5
250 configure:4797: $? = 0

    There was a potential problem with the macro though (I keep on
forgetting that AC_TRY_COMPILE and AC_COMPILE_IFELSE work predefine
main() with the block of code provided), so please let me know if
things work for you.
Thanks,
-Garrett

------------------------------------------------------------------------------
Centralized Desktop Delivery: Dell and VMware Reference Architecture
Simplifying enterprise desktop deployment and management using
Dell EqualLogic storage and VMware View: A highly scalable, end-to-end
client virtualization framework. Read more!
http://p.sf.net/sfu/dell-eql-dev2dev
_______________________________________________
Ltp-list mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/ltp-list

Reply via email to