The CC and CXX variables imported from the Yocto build environment may contain additional compiler flags after the compiler name. Extract those and add them to cmake toolchain file variables, too.
Signed-off-by: Thomas Elste <thomas.el...@imms.de> --- Hi, using the Yocto plugin for Eclipse to generate CMake based C projects I've encountered a problem. I'm using a standalone armhf toolchain (ADT) for building the project. Compiling works fine but linkings fails due to a mismatch in the FP ABI of object files and target sysroot libraries. This happens as the compiler is not called with all the flags necessary. The flags which appear in the environment file of the ADT in the CC/CXX variable are not present. For example CC for my toolchain looks like this: export CC="arm-poky-linux-gnueabi-gcc -march=armv7-a -mfloat-abi=hard -mfpu=neon -mtune=cortex-a7 --sysroot=$SDKTARGETSYSROOT" Everything after the compiler name does not get integrated into the CMake toolchain file generated by the Eclipse plugin (which in case of the float-abi flag leads to the previous mentioned build error). So I propose the attached patch, which adds everything found (except sysroot entries) after the compiler name in the C/CXX build environment variable to the CMake toolchain file (OECMAKE_C_FLAGS, etc.). Best regards Thomas .../ide/natures/YoctoSDKCMakeProjectNature.java | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/plugins/org.yocto.sdk.ide/src/org/yocto/sdk/ide/natures/YoctoSDKCMakeProjectNature.java b/plugins/org.yocto.sdk.ide/src/org/yocto/sdk/ide/natures/YoctoSDKCMakeProjectNature.java index b3d0f2c..44ccfe6 100644 --- a/plugins/org.yocto.sdk.ide/src/org/yocto/sdk/ide/natures/YoctoSDKCMakeProjectNature.java +++ b/plugins/org.yocto.sdk.ide/src/org/yocto/sdk/ide/natures/YoctoSDKCMakeProjectNature.java @@ -45,19 +45,33 @@ public class YoctoSDKCMakeProjectNature extends YoctoSDKProjectNature { IEnvironmentVariable.ENVVAR_REPLACE, delimiter, ccdesc); String ccString = YoctoSDKUtils.getEnvValue(project, "CC"); + String ccFlagsString = ""; if (!ccString.equals("") && !ccString.equals(" ")) { ccString.trim(); - ccString = ccString.split(" ")[0]; + String[] ccSplitString = ccString.split(" "); + ccString = ccSplitString[0]; + + for(int i=1; i<ccSplitString.length; i++) { + if(ccSplitString[i].indexOf("sysroot")<0) + ccFlagsString+=ccSplitString[i] + " "; + } } env.addVariable("OECMAKE_C_COMPILER", ccString, IEnvironmentVariable.ENVVAR_REPLACE, delimiter, ccdesc); String cxxString = YoctoSDKUtils.getEnvValue(project, "CXX"); + String cxxFlagsString = ""; if (!cxxString.equals("") && !cxxString.equals(" ")) { cxxString.trim(); - cxxString = cxxString.split(" ")[0]; + String[] cxxSplitString = cxxString.split(" "); + cxxString = cxxSplitString[0]; + + for(int i=1; i<cxxSplitString.length; i++) { + if(cxxSplitString[i].indexOf("sysroot")<0) + cxxFlagsString+=cxxSplitString[i] + " "; + } } env.addVariable("OECMAKE_CXX_COMPILER", cxxString, @@ -65,8 +79,8 @@ public class YoctoSDKCMakeProjectNature extends YoctoSDKProjectNature { String hostCCArchString = YoctoSDKUtils.getEnvValue(project, "HOST_CC_ARCH"); String toolchainOptionsString = YoctoSDKUtils.getEnvValue(project, "TOOLCHAIN_OPTIONS"); - String cppFlagsString = YoctoSDKUtils.getEnvValue(project, "CPPFLAGS"); - String cxxFlagsString = YoctoSDKUtils.getEnvValue(project, "CXXFLAGS"); + String cppFlagsString = YoctoSDKUtils.getEnvValue(project, "CPPFLAGS") + " " + ccFlagsString; + cxxFlagsString = YoctoSDKUtils.getEnvValue(project, "CXXFLAGS") + " " + cxxFlagsString; String selectedOptimizationString = YoctoSDKUtils.getEnvValue(project, "SELECTED_OPTIMIZATION"); env.addVariable("OECMAKE_C_FLAGS", hostCCArchString + " " + toolchainOptionsString + " " + cppFlagsString, IEnvironmentVariable.ENVVAR_REPLACE, delimiter, ccdesc); -- 2.4.10 -- _______________________________________________ yocto mailing list yocto@yoctoproject.org https://lists.yoctoproject.org/listinfo/yocto