omniorb: cleanup autobuild failure, CFLAGS issue

Fixed:
http://autobuild.buildroot.net/results/a08baf8821e3ee1fb9c36c8f74c4ced466af167b/
http://autobuild.buildroot.net/results/f0c7379c1f405385d3a64c0349c3d9565065e8a7/
http://autobuild.buildroot.net/results/c3de25ca52fdb8ffda7472cf9f7b64514954cbb1/

Change Log:
The target CFLAGS were getting mixed in during a manual build of some
omniorb pkg tools that could be viewed as host tools.
This manual build was a dirty workaround and created some bad
cornercases. So I converted the package over to actually using the
host pkg build and removed the need for a patch and custom mods in the build.

Also there wasn't a dependency on the target having python, just
host-python for performing the initial build.  So depends were adjusted
accordingly. If python bindings are required, they can be found in a different
package called omniORBpy.  The omniORB package only uses python for
the build process.

Fixed a bug with long double support.  Currently leaving it disabled
as most targets won't use it.  This allows greater toolchain compatibility.

Signed-off-by: Matt Weber <mlweber1@rockwellcollins.com>
Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
This commit is contained in:
Matt Weber 2013-10-01 15:34:19 -05:00 committed by Peter Korsgaard
parent 97c687000a
commit dd7981bfd2
1 changed files with 24 additions and 29 deletions

View File

@ -10,37 +10,32 @@ OMNIORB_SOURCE = omniORB-$(OMNIORB_VERSION).tar.bz2
OMNIORB_INSTALL_STAGING = YES OMNIORB_INSTALL_STAGING = YES
OMNIORB_LICENSE = GPL2+ LGPLv2.1+ OMNIORB_LICENSE = GPL2+ LGPLv2.1+
OMNIORB_LICENSE_FILES = COPYING COPYING.LIB OMNIORB_LICENSE_FILES = COPYING COPYING.LIB
# Required for internal code generation scripts OMNIORB_DEPENDENCIES = host-omniorb
OMNIORB_DEPENDENCIES = host-python HOST_OMNIORB_DEPENDENCIES = host-python
OMNIORB_INSTALL_TARGET = YES
ifeq ($(BR2_PACKAGE_PYTHON),y) # Defaulting long double support to a safe option for the
OMNIORB_DEPENDENCIES += python # mix of embedded targets, this could later be automated
OMNIORB_CONF_OPT += --enable-python-bindings # based on checking the capability of the cross toolchain
else # for "__LONG_DOUBLE_128__". Currently the host and target
OMNIORB_CONF_OPT += --disable-python-bindings # need to match because of the code generation done by the
endif # host tools during the target compile (ie headers generated
# on host are used in target build).
OMNIORB_CONF_OPT += --disable-longdouble
HOST_OMNIORB_CONF_OPT += --disable-longdouble
# omniORB is currently not cross-compile friendly and has some assumptions # omniORB is not completely cross-compile friendly and has some
# where a couple host tools are built in place and then used during the # assumptions where a couple host tools must be built and then
# build. The tools generate code from the IDL description language, which # used by the target build. The host tools generate code from
# is then built into the cross compiled OMNIORB application. # the IDL description language, which is then built into the
# So this first hook builds the tools required for the host side # cross compiled target OMNIORB application.
# generation of code. Then the second hook cleans up before the install. define OMNIORB_ADJUST_TOOLDIR
define OMNIORB_BUILD_TOOLS # Point to the host folder to get HOST_OMNIORB tools
$(HOST_MAKE_ENV) $(MAKE) $(HOST_CONFIGURE_OPTS) \ $(SED) 's:TOOLBINDIR = $$(TOP)/$$(BINDIR):TOOLBINDIR = $(HOST_DIR)/usr/bin:g' $(@D)/mk/beforeauto.mk
-C $(@D)/src/tool export # Disables OMNIORB tool building
echo "EmbeddedSystem=1" >> $(@D)/mk/beforeauto.mk
endef endef
OMNIORB_POST_CONFIGURE_HOOKS += OMNIORB_BUILD_TOOLS OMNIORB_POST_CONFIGURE_HOOKS += OMNIORB_ADJUST_TOOLDIR
define OMNIORB_CLEAN_TOOLS
$(HOST_MAKE_ENV) $(MAKE) $(HOST_CONFIGURE_OPTS) \
-C $(@D)/src/tool clean
endef
OMNIORB_POST_BUILD_HOOKS += OMNIORB_CLEAN_TOOLS
define OMNIORB_FIXUP_FILE_PATHS_HOOK
$(SED) "s:$(HOST_DIR)/usr:/usr:g" $(STAGING_DIR)/usr/bin/omniidl
endef
OMNIORB_POST_INSTALL_STAGING_HOOKS += OMNIORB_FIXUP_FILE_PATHS_HOOK
$(eval $(autotools-package)) $(eval $(autotools-package))
$(eval $(host-autotools-package))