Date
1 - 4 of 4
Trying to create OpenDDS recipe
Paul Ourada
I hope this is the correct place to post this. If not, please let me
know. I'm trying to create a recipe for OpenDDS. The recipe works so far as fetching, unpacking, and configuration. Or it seems to. :) Part of the configuration piece is that it also pulls down ACE+TAO real-time CORBA. This part works fine as well. I set S as follows to match the unpacking directories enforced by the tar file: S = ${WORKINGDIR}/DDS The package comes with a configuration script pre-built, and it expects to be told where glibc is. So, I write do_configure as follows: EXTRA_OECONF = "-glibc=${STAGING_DIR}/${MACHINE}/usr" do_configure() { ${S}/configure ${EXTRA_OECONF} } The problem that I run into is during compilation. I write the following for do_compile() do_compile() { oenote ${STAGING_DIR} cd ${S} && make } This works right up until there is a compile error in ACE+TAO. Of course, I build the entire DDS package, including ACE+TAO, with no hiccups in Ubuntu, so I understand that this is a cross-compile/environment issue. The compile error is that it cannot find features.h, which is clearly in ${STAGING_LIBDIR}/${MACHINE}/usr/include. The compile command which is being executed is as follows (this is going to be ugly, let me know if there's a better way to include this, such as a pastebin somewhere): | make[1]: Entering directory `/opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE _wrappers/TAO/TAO_IDL' | | GNUmakefile: /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/TAO/TAO_IDL/GNUmakefile.TAO_IDL_EXE MAKEFLAGS=w | | i586-poky-linux-g++ -march=i586 --sysroot=/opt/yocto/poky-5.0.1-build/tmp/sysroots/qemux86 -fvisibility=hidden -fvisibility-inlines-hidden -W -Wall -Wpointer-arith -ggdb -pipe -D_REENTRANT -DACE_HAS_AIO_CALLS -D_GNU_SOURCE -I/opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/AC E_wrappers -DACE_HAS_EXCEPTIONS -DACE_NO_INLINE -I../.. -Iinclude -Ibe_include -Ife -I.. -DTAO_IDL_PREPROCESSOR=\"i586-poky-linux-g++ -march=i586 --sysroot=/opt/yocto/poky-5.0.1-build/tmp/sysroots/qemux86\" -c -o .obj/driver/drv_preproc.o driver/drv_preproc.cpp | <command-line>:0:22: warning: missing terminating " character | In file included from /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/config-linux-common.h:30:0, | from /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/config-linux.h:14, | from /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/config.h:1, | from /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/config-macros.h:24, | from /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/config-lite.h:24, | from /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/os_include/os_limits.h:21, | from include/idl_defines.h:70, | from driver/drv_preproc.cpp:70: | /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE_ wrappers/ace/config-posix.h:7:20: fatal error: unistd.h: No such file or directory | compilation terminated. | make[1]: *** [.obj/driver/drv_preproc.o] Error 1 | make[1]: Leaving directory `/opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/ACE _wrappers/TAO/TAO_IDL' | make: *** [TAO_IDL_EXE] Error 2 | ERROR: Function 'do_compile' failed (see /opt/yocto/poky-5.0.1-build/tmp/work/i586-poky-linux/opendds-2.3-r0/temp /log.do_compile.17412 for further information) NOTE: package opendds-2.3-r0: task do_compile: Failed ERROR: Task 5 (/opt/yocto/poky-bernard-5.0.1/meta/recipes-middleware/opendds/opendds_2 .3.bb, do_compile) failed with exit code '1' The thing that is puzzling me is that --sysroot seems to be pointing in the general direction of ${STAGING_DIR} and so the include directive, #include <features.h> should be good. I have checked, and features.h is in the /usr/include subdirectory there. Does anyone have a clue they could lend me? Thanks, Paul E. Ourada Sr. Principal Software Engineer Covidien, Energy-based Devices 5920 Longbow Drive Boulder, CO 80301 paul.ourada@... www.covidien.com Main: 303-530-2300 Ofc: 303-581-6940 Fax: 303-581-6741 |
|
Darren Hart <dvhart@...>
Hi Paul,
On 07/19/2011 07:41 AM, Ourada, Paul wrote: I hope this is the correct place to post this. If not, please let meThis is the right place. In the future please don't reply to an existing post as your message then gets threaded with the one you replied to (likely why you didn't receive a response so far - that I see anyway). Is there a reason you are overriding configure and compile? These appear to be autoconf projects, which should just work for recipes using autotools.bbclass. This is better - the pastebin isn't as reliable, and having it inline to review and for future reference is much preferred. Do you see unistd.h under /opt/yocto/poky-5.0.1-build/tmp/sysroots/qemux86 ? | compilation terminated.I see unistd.h missing, not features.h. -- Darren -- Darren Hart Intel Open Source Technology Center Yocto Project - Linux Kernel |
|
Paul Ourada
Hi Darren -
Thanks for getting back to me. I have been able to get a lot further with the recipe. It turns out that the problem is in the makefiles for OpenDDS. I'll detail further below. Paul E. Ourada Sr. Principal Software Engineer Covidien, Energy-based Devices 5920 Longbow Drive Boulder, CO 80301 paul.ourada@... www.covidien.com Main: 303-530-2300 Ofc: 303-581-6940 Fax: 303-581-6741 Hi Paul,On 07/19/2011 07:41 AM, Ourada, Paul wrote: I hope this is the correct place to post this. If not, please let me This is the right place. In the future please don't reply to an existingI guess I thought that changing the subject would have fixed that. Guess the mail list s/w is smarter than that. :)
Is there a reason you are overriding configure and compile? These appearI had tried that initially. The configuration file is already supplied, so running autotools to create the configure script is not necessary, but running ./configure is. Is there a better way to do that? : : << most of the compiler command line gobblety-gook snipped>> -DTAO_IDL_PREPROCESSOR=\"i586-poky-linux-g++ The thing that is puzzling me is that --sysroot seems to be pointing in I see unistd.h missing, not features.h.You're right, it was complaining about unistd.h, but it turns out that the real culprit was the TAO_IDL_PREPROCESSOR macro above. When I compared it to what was being emitted in the Ubuntu compile, I saw that the long, nasty, compound, double-quoted thing should have just been "i586-poky-linux-g++." TAO_ID_PREPROCESSOR was being assigned the value of ${CXX}. It appears that instead of pre-pending the ${CPPFLAGS} variable, yocto/poky recipes were appending the cross-compile build variables to ${CXX}. I patched the OpenDDS makefile(s) to look for the first word in the ${CXX} macro, and substituted that in the assignment of TAO_IDL_PREPROCESSOR. Dunno if that's the "right" way to do it, or if there's a bug in ${CXX} assignment? Anyway, I think that I'm getting there w/the recipe. I'm sure that there are some things I'm doing wrong. For instance, I'm no longer cd'ing to ${S}, as OE already takes me there. I'm also using oe_runmake in do_compile(). I expect that I'll be running some version of "make install" at some point. I'm sure I'll have more questions as I go along. Thanks for helping an OE/Yocto N00b! Paul |
|
Darren Hart <dvhart@...>
Nitin, Khem, some toolchain related (I think) questions inline below.
On 07/28/2011 04:16 PM, Ourada, Paul wrote: Hi Darren -In case you're actually curious :-) it's your mail client. It inserts the following header: In-Reply-To: <E7D51FCF-F5DC-448D-8354-410E0217D10F@...> Which a compliant mail reader will thread with that message. Does regenerating .configure actually cause a problem? If not, I would still suggest using the autotools base and simplify your recipe. These are good toolchain questions for Nitin or Khem, now on CC. If you're running oe_runmake from do_compile then you might be able to omit do_compile and use the base class implementation. Again, should be automagic. -- Darren Hart Intel Open Source Technology Center Yocto Project - Linux Kernel |
|