[英]How do I update my libthread_db shared library so as to match libpthread shared library?
[英]How do I link librt and libpthread to a new layer in Yocto?
這個問題如下
我在哪里可以找到關於 aarch64-poky-linux-ld 的文檔?
請忽略外部雙引號集。 他們似乎有必要讓“StackOverflow”接受我的輸入。
我的層是“meta-oca-so”,它的 package 是“oca”,它的配方是 oca_1.2.7.bb。
我修改了我的“oca makefile”來修復之前的錯誤和一些 linker 錯誤,這些錯誤與無效的鏈接標志有關,當我執行“bitbake oca”時,我現在可以將完整的 29 個“oca”.a 庫鏈接在一起。 在更改鏈接標志和重做“bitbake oca”時,我不必做任何清理工作。
現在,當我執行“bitbake oca”時,錯誤消息是:
~/Yocto/imx-yocto-bsp/build-wayland/tmp/work/aarch64-poky-linux/oca/1.2.7-r0/oca-1.2.7/Obj/linuxApp/Release/OcaProto
aarch64-poky-linux-ld: cannot find -lstdc++
aarch64-poky-linux-ld: cannot find -lrt
aarch64-poky-linux-ld: cannot find -lpthread
aarch64-poky-linux-ld: cannot find -ldns_sd
在這個問題中關注“librt”和“libpthread”,我將這些行添加到我的“local.conf”中:
IMAGE_INSTALL_append=" librt"
TOOLCHAIN_TARGET_TASK_append=" librt"
IMAGE_INSTALL_append=" libpthread"
TOOLCHAIN_TARGET_TASK_append=" libpthread"
但是當我重做“bitbake oca”時,它並沒有清除它的兩個鏈接錯誤。
當我嘗試整體“bitbake imx-image-multimedia”時,我收到了關於“librt”的這些消息:
NOTE: Resolving any missing task queue dependencies
ERROR: Nothing RPROVIDES 'librt' (but /home/james/Yocto/imx-yocto-bsp/sources/meta-imx/meta-sdk/recipes-fsl/images/imx-image-multimedia.bb RDEPENDS on or otherwise requires it)
NOTE: Runtime target 'librt' is unbuildable, removing...
Missing or unbuildable dependency chain was: ['librt']
ERROR: Required build target 'imx-image-multimedia' has no buildable providers.
Missing or unbuildable dependency chain was: ['imx-image-multimedia', 'librt']
很難找到關於“rt”的很多信息,因為這個兩個字母的組合在統計上並非不可能。
同樣,當我從“local.conf”中注釋掉兩個“librt”行並重試“bitbake imx-image-multimedia”時,我收到了關於“libpthread”的這些消息:
ERROR: Nothing RPROVIDES 'libpthread' (but /home/james/Yocto/imx-yocto-bsp/sources/meta-imx/meta-sdk/recipes-fsl/images/imx-image-multimedia.bb RDEPENDS on or otherwise requires it)
NOTE: Runtime target 'libpthread' is unbuildable, removing...
Missing or unbuildable dependency chain was: ['libpthread']
ERROR: Required build target 'imx-image-multimedia' has no buildable providers.
Missing or unbuildable dependency chain was: ['imx-image-multimedia', 'libpthread']
如何獲得“librt”和“libpthread”?
我需要每個添加一個圖層來構建它們嗎? 每個人都需要支持包的“依賴地獄”樹嗎?
這是相關的 makefile 組件 makeOCA.inc。 OCA項目中有63個不同描述、不同級別的“make”文件。 它很長,大約 1070 行。 我剪掉了非 Linux 系統的部分; 我只關心這里的 linuxRelease。
# Project : OCA
# Module : Multiple components
# Description : Include file for C / CPP makefiles.
#
################################################################################
# Environment variable checking
################################################################################
#
# If one of the variables below is not set,
# calling make will result in a "missing separator" error.
#
ifeq ($(CAP_HOME),)
variable CAP_HOME is not set
else
CAP_HOME := $(patsubst %/,%,$(subst \,/,$(CAP_HOME)))
endif
################################################################################
# Variables
################################################################################
ifeq ($(NAME_MKE),)
NAME_MKE := makefileOCA
endif
ifeq ($(IGNORE_MAKE_ERRORS),Y)
PREFIX := -@
else
ifneq ($(DISPLAY_MAKE_CMDS),Y)
PREFIX := @
endif
endif
EMPTY :=
SPACE := $(EMPTY) $(EMPTY)
#
# Only set variables when the makefile is called with an actual target
# (not a phony one).
#
ifneq ($(PLATFORM),)
ifneq ($(RELEASE),)
# Project home
PRJ_HOME := $(CAP_HOME)
# Src home
SRC_HOME := $(PRJ_HOME)/Src
# Include directories
ifneq ($(USRINC),)
INCDIRS := $(subst ; ,;,$(subst \,/,.;\
$(SRC_HOME)/inc;\
$(SRC_HOME)/lib/inc;\
$(SRC_HOME)/common;\
$(SRC_HOME)/common/OCA;\
$(SRC_HOME)/common/HostInterface;\
$(SRC_HOME)/platform;\
$(SRC_HOME)/platform/common;\
$(SRC_HOME)/adamson;\
$(USRINC)))
else
INCDIRS := $(subst ; ,;,$(subst \,/,.;\
$(SRC_HOME)/inc;\
$(SRC_HOME)/lib/inc;\
$(SRC_HOME)/common;\
$(SRC_HOME)/common/OCA;\
$(SRC_HOME)/common/HostInterface;\
$(SRC_HOME)/platform;\
$(SRC_HOME)/platform/common;\
$(SRC_HOME)/adamson))
endif
# Output directories
OBJDIR := Obj
OBJINT := intermediate
OUTDIR := $(subst \,/,$(PRJ_HOME))/$(OBJDIR)/$(PLATFORM)/$(RELEASE)
ifeq ($(GINTDIR),)
GINTDIR := $(OUTDIR)/$(OBJINT)
endif
INTDIR := $(GINTDIR)/$(NAME)
# Tools
SD := CC -M -MP -march=native
SE := sed
RC :=
ifeq ($(OS),Windows_NT)
RM := erase /F
MD := mkdir
RN := ren _PATH__OLDNAME_ _NEWNAME_
RD := rd /s/q
else
RM := rm -f
MD := mkdir -p
RN := mv _PATH__OLDNAME_ _PATH__NEWNAME_
RD := rm -rf
endif
# Commands
ifeq ($(OS),Windows_NT)
IFEXIST := if exist _FILE_ _COMMAND_
IFNOTEXIST := if not exist _FILE_ _COMMAND_
else
IFEXIST := if [ -e "_FILE_" ]; then _COMMAND_; fi
IFNOTEXIST := if [ ! -e "_FILE_" ]; then _COMMAND_; fi
endif
# Other OS dependent variables
# Work around to make sure only a single backslash is set
ifeq ($(OS),Windows_NT)
PATH_SEP := $(subst \\,\,\\)
else
PATH_SEP := $(subst \\,/,/)
endif
ifeq ($(PLATFORM),winntApp)
CXXFLAGS :=
RCFLAGS := -I "$(subst ;," -I ",$(INCDIRS))"
### linuxRelease ###############################################################
ifeq ($(RELEASE),Release)
# Tools
# CC := gcc
# Determine the extensions for the target platform
OBJ_EXT := o
DEP_EXT := dep
EXE_EXT :=
LIB_EXT := a
DLL_EXT := so
# Lists
OBJS := $(patsubst %.cpp,%.$(OBJ_EXT),$(SRCS) $(LINUXSRCS))
OBJS := $(patsubst %.c,%.$(OBJ_EXT),$(OBJS))
DEPS := $(patsubst %.$(OBJ_EXT),%.$(DEP_EXT),$(OBJS))
LIBS := $(LIBS) $(LINUXLIBS) $(EXTERNAL_LIBS)
LIBS := $(addsuffix .$(LIB_EXT), $(LIBS))
LIBS := $(addprefix $(OUTDIR)/, $(LIBS))
SDFLAGS := -O2 -nostdlib -fno-strict-aliasing -ffunction-sections -fdata-sections -c -Wall -Wno-unknown-pragmas -x none \
-I"$(subst ;," -I",$(INCDIRS))" \
-D"NDEBUG" -DTARGET_LINUX -D"CPPUNIT_TUI_VERSION" -D"__STDC_FORMAT_MACROS" \
$(foreach USRDEF,$(USRDEFS),-D"$(USRDEF)") \
$(foreach USRUNDEF,$(USRUNDEFS),-U"$(USRUNDEF)")
SDCFLAGS :=
SDCPPFLAGS := -std=c++0x
CCFLAGS = $(SDFLAGS) -fexceptions -fvisibility=hidden -march=armv8-a -mtune=cortex-a53 -o $(INTDIR)/$@
# That's for Linaro and the Snapdragon410 (Qualcomm APQ8016) processor; next is for Ubuntu 18.04.1
# CCFLAGS = $(SDFLAGS) -fexceptions -fvisibility=hidden -m64 -mtune=generic -o $(INTDIR)/$@
CXXFLAGS := -std=gnu++0x
ifeq ($(TYPE),EXE)
OUT_EXT := $(EXE_EXT)
# LD := gcc
LD := aarch64-poky-linux-ld
# LDFLAGS = -Wl,--gc-sections -fno-keep-static-consts -fexceptions -march=armv8-a -maarch64linux -L$(OUTDIR) -o$@
# Use the above -Wl when using gcc. When using ld directly, it doesn't take -Wl. aarch64-poky-linux-ld doesn't have the -f options.
LDFLAGS = --gc-sections -march=armv8-a -maarch64linux -L$(OUTDIR) -o$@
# That's for Linaro and the Snapdragon410 (Qualcomm APQ8016) processor; next is for Ubuntu 18.04.1
# LDFLAGS = -Wl,--gc-sections -fno-keep-static-consts -fexceptions -m64 -mtune=x86-64 -L$(OUTDIR) -o$@
LINUXSYSTEMLIBS := -lstdc++ -lrt -lpthread $(addprefix -l, $(LINUXSYSTEMLIBS))
endif
ifeq ($(TYPE),LIB)
OUT_EXT := $(LIB_EXT)
# LD := ar
LDFLAGS = crus $@
endif
ifeq ($(TYPE),DLL)
OUT_EXT := $(DLL_EXT)
# LD := gcc
LD := aarch64-poky-linux-ld
# LDFLAGS = -Wl,--gc-sections -export-dynamic -fno-keep-static-consts -fexceptions -march=armv8-a -maarch64linux -L$(OUTDIR) -o$@
# Use the above -Wl when using gcc. When using ld directly, it doesn't take -Wl. aarch64-poky-linux-ld doesn't have the -f options.
LDFLAGS = --gc-sections -export-dynamic -march=armv8-a -maarch64linux -L$(OUTDIR) -o$@
# That's for Linaro and the Snapdragon410 (Qualcomm APQ8016) processor; next is for Ubuntu 18.04.1
# LDFLAGS = -Wl,--gc-sections -export-dynamic -fno-keep-static-consts -fexceptions -m64 -mtune=x86-64 -L$(OUTDIR) -o$@
LINUXSYSTEMLIBS := -lstdc++ -lrt -lpthread $(addprefix -l, $(LINUXSYSTEMLIBS))
endif
endif
endif #ifeq ($(PLATFORM),linuxApp)
endif #ifneq ($(RELEASE),)
endif #ifneq ($(PLATFORM),)
################################################################################
# Phony target specification
################################################################################
.PHONY: goal all clean phonyclean $(NAME)\
winntDebug winntRelease \
winntDebug64 winntRelease64 \
winntDebugClean winntReleaseClean \
winntDebug64Clean winntRelease64Clean \
linuxDebug linuxRelease \
linuxDebugClean linuxReleaseClean
################################################################################
# Targets
################################################################################
goal: winntDebug winntRelease
all: winntDebug winntRelease \
winntDebug64 winntRelease64
clean: winntDebugClean winntReleaseClean \
winntDebug64Clean winntRelease64Clean
linuxRelease:
ifneq (,$(findstring linux,$(TARGETS)))
$(PREFIX)$(MAKE) -f $(NAME_MKE) $(NAME) --no-print-directory PLATFORM=linuxApp RELEASE=Release
else
$(PREFIX)echo $@ not configured for $(NAME)
endif
linuxReleaseClean:
ifneq (,$(findstring linux,$(TARGETS)))
$(PREFIX)$(MAKE) -f $(NAME_MKE) phonyclean --no-print-directory PLATFORM=linuxApp RELEASE=Release CLEAN=Yes
else
$(PREFIX)echo linuxRelease not configured for $(NAME)
endif
### Dependency files ###########################################################
$(INTDIR)/%.$(DEP_EXT) : %.c
$(PREFIX)echo $(@F)
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$@),$(subst _COMMAND_,$(RM) $(subst /,$(PATH_SEP),$@),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$@.tmp),$(subst _COMMAND_,$(RM) $(subst /,$(PATH_SEP),$@.tmp),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(GINTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(GINTDIR)),$(IFNOTEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(INTDIR)),$(IFNOTEXIST)))
#
# Do not use (OBJ_EXT) in the SED command, since all dependencies are generated with gcc.
# Use .o instead
#
$(PREFIX)$(SD) $(SDCFLAGS) $(SDFLAGS) $< | $(SE) "s/$*.o:/$*.$(OBJ_EXT) $(subst /,\/,$@):/" > $(subst /,$(PATH_SEP),$@.tmp)
$(PREFIX)$(subst _PATH_,$(subst /,$(PATH_SEP),$(INTDIR)/),$(subst _OLDNAME_,$(@F).tmp,$(subst _NEWNAME_,$(@F),$(RN))))
$(INTDIR)/%.$(DEP_EXT) : %.cpp
$(PREFIX)echo $(@F)
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$@),$(subst _COMMAND_,$(RM) $(subst /,$(PATH_SEP),$@),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$@.tmp),$(subst _COMMAND_,$(RM) $(subst /,$(PATH_SEP),$@.tmp),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(GINTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(GINTDIR)),$(IFNOTEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(INTDIR)),$(IFNOTEXIST)))
#
# Do not use (OBJ_EXT) in the SED command, since all dependencies are generated with gcc.
# Use .o instead
#
$(PREFIX)$(SD) $(SDCPPFLAGS) $(SDFLAGS) $< | $(SE) "s/$*.o:/$*.$(OBJ_EXT) $(subst /,\/,$@):/" > $(subst /,$(PATH_SEP),$@.tmp)
$(PREFIX)$(subst _PATH_,$(subst /,$(PATH_SEP),$(INTDIR)/),$(subst _OLDNAME_,$(@F).tmp,$(subst _NEWNAME_,$(@F),$(RN))))
### Object files ###############################################################
%.$(OBJ_EXT) : %.asm
$(PREFIX)echo $(@F)
$(PREFIX)$(AS) $(ASFLAGS) $<
%.$(OBJ_EXT) : %.S
$(PREFIX)echo $(@F)
$(PREFIX)$(AS) $(ASFLAGS) $<
%.$(RES_EXT) : %.rc
$(PREFIX)echo $(@F)
$(PREFIX)"$(RC)" $(RCFLAGS) -fo "$(INTDIR)/$(@F)" $<
%.$(OBJ_EXT) : %.c $(TOOL_DEPS)
ifneq ($(CC),cl.exe)
$(PREFIX)echo $(@F)
endif
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)/$@),$(subst _COMMAND_,$(RM) $(subst /,$(PATH_SEP),$(INTDIR)/$@),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(INTDIR)),$(IFNOTEXIST)))
$(PREFIX)$(CC) $(CCFLAGS) $<
%.$(OBJ_EXT) : %.cpp $(TOOL_DEPS)
ifneq ($(CC),cl.exe)
$(PREFIX)echo $(@F)
endif
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)/$@),$(subst _COMMAND_,$(RM) $(subst /,$(PATH_SEP),$(INTDIR)/$@),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(INTDIR)),$(IFNOTEXIST)))
$(PREFIX)$(CC) $(CCFLAGS) $(CXXFLAGS) $<
### Output file ################################################################
$(NAME): $(OUTFILE) $(BINFILE)
$(OUTFILE): $(INTDIR)/$(NAME).x $(OBJS) $(LIBS) $(NAME_MKE)
$(PREFIX)echo $@
$(PREFIX)$(subst _FILE_,$@,$(subst _COMMAND_,$(RM) $@,$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(OUTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(OUTDIR)),$(IFNOTEXIST)))
ifneq (,$(findstring $(OBJINT),$(OBJS)))
$(foreach obj,$(OBJS),$(shell echo $(obj) >> $(LSTFILE)))
else
$(foreach obj,$(OBJS),$(shell echo $(subst /,$(PATH_SEP),$(INTDIR)/$(obj)) >> $(LSTFILE)))
endif
ifneq (,$(filter $(PLATFORM),linuxApp))
ifeq ($(TYPE),LIB)
$(PREFIX)ar $(LDFLAGS) @$(LSTFILE) $(LIBS) $(LINUXSYSTEMLIBS)
else
ifeq ($(TYPE),EXE)
$(PREFIX)aarch64-poky-linux-ld $(LDFLAGS) @$(LSTFILE) $(LIBS) $(LINUXSYSTEMLIBS)
else
ifeq ($(TYPE),DLL)
$(PREFIX)aarch64-poky-linux-ld $(LDFLAGS) @$(LSTFILE) $(LIBS) $(LINUXSYSTEMLIBS)
else
$(PREFIX)LD $(LDFLAGS) @$(LSTFILE) $(LIBS) $(LINUXSYSTEMLIBS)
endif
endif
endif
else
ifeq ($(PLATFORM),winntApp)
$(PREFIX)$(LD) $(LDFLAGS) @$(LSTFILE) $(WINNTSYSTEMLIBS)
else
$(PREFIX)$(LD) $(LDFLAGS) @$(LSTFILE)
endif
endif
$(PREFIX)$(subst _FILE_,$(LSTFILE),$(subst _COMMAND_,$(RM) $(LSTFILE),$(IFEXIST)))
$(BINFILE): $(OUTFILE)
$(PREFIX)echo $@
$(PREFIX)$(B2B) $(B2BFLAGS) $(OUTFILE) $(BINFILE)
$(INTDIR)/$(NAME).x:
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)),$(subst _COMMAND_,$(MD) $(subst /,$(PATH_SEP),$(INTDIR)),$(IFNOTEXIST)))
$(PREFIX)echo Checkpoint file for component $(NAME) > $(subst /,$(PATH_SEP),$@)
### Clean ######################################################################
phonyclean:
ifneq ($(PLATFORM),)
ifneq ($(RELEASE),)
$(PREFIX)$(subst _FILE_,$(subst /,$(PATH_SEP),$(INTDIR)),$(subst _COMMAND_,$(RD) $(subst /,$(PATH_SEP),$(INTDIR)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(patsubst %.$(OUT_EXT),%.pdb,$(OUTFILE)),$(subst _COMMAND_,$(RM) $(patsubst %.$(OUT_EXT),%.pdb,$(OUTFILE)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(patsubst %.$(OUT_EXT),%.map,$(OUTFILE)),$(subst _COMMAND_,$(RM) $(patsubst %.$(OUT_EXT),%.map,$(OUTFILE)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(patsubst %.$(OUT_EXT),%.dat,$(OUTFILE)),$(subst _COMMAND_,$(RM) $(patsubst %.$(OUT_EXT),%.dat,$(OUTFILE)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(patsubst %.$(OUT_EXT),%.exp,$(OUTFILE)),$(subst _COMMAND_,$(RM) $(patsubst %.$(OUT_EXT),%.exp,$(OUTFILE)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(patsubst %.$(OUT_EXT),%.lib,$(OUTFILE)),$(subst _COMMAND_,$(RM) $(patsubst %.$(OUT_EXT),%.lib,$(OUTFILE)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(patsubst %.$(OUT_EXT),%.err,$(OUTFILE)),$(subst _COMMAND_,$(RM) $(patsubst %.$(OUT_EXT),%.err,$(OUTFILE)),$(IFEXIST)))
$(PREFIX)$(subst _FILE_,$(OUTFILE),$(subst _COMMAND_,$(RM) $(OUTFILE),$(IFEXIST)))
else
$(PREFIX)echo Target $@ should not be used from command line
endif
else
$(PREFIX)echo Target $@ should not be used from command line
endif
################################################################################
# Include dependency files
################################################################################
ifneq ($(PLATFORM),)
ifneq ($(RELEASE),)
#
# If cleaning, we must not include dependency files.
# Otherwise they will be created before cleaning.
#
ifeq ($(CLEAN),)
ifeq (,$(findstring $(OBJINT),$(OBJS)))
#
# Use a - in front of the include, otherwise make will complain
# when it is ran the first time (when there are no .dep files).
#
-include $(patsubst %.$(DEP_EXT),$(INTDIR)/%.$(DEP_EXT),$(DEPS))
endif
endif
endif
endif
有人可以指出一個完整的 Yocto 層的簡單示例,包括 makefile 和交叉編譯的簡單代碼嗎? 我似乎很難找到,尤其是支持用於交叉編譯的makefile。
一個重要的認識是文檔是關於 CFLAGS 和 LDFLAGS 的路徑變量和其他設置的:在 Yocto 大型手冊中的所有變量,在“第 33 章。變量詞匯表”, https://www.yoctoproject.org/ docs/3.0/mega-manual/mega-manual.html#ref-variables-glos
首先,您似乎在 Yocto 中混合了各種依賴概念:
IMAGE_INSTALL
是一個圖像依賴項,告訴 Yocto 參數中的配方必須安裝在最終圖像中。 它應該放在圖像配方中,而不是 package 配方中。 我不認為將其添加到 package 配方中會告訴 Yocto 將此依賴項添加到配方的暫存目錄中。RDEPENDS
在 package 配方中使用,並告訴 Yocto 配方取決於運行時參數中的包。 然后,如果您安裝需要它們的 package,它將在最終映像中安裝所需的運行時依賴項。DEPENDS
也在 package 配方中使用,並告訴 Yocto 配方取決於編譯時參數中的包。 它將在配方的暫存目錄中添加 header 文件和庫。 話雖如此, libstdc++
、 libpthread
和librt
是工具鏈的一部分,您無需為此在配方中添加顯式依賴項。 它們將毫不費力地安裝在暫存目錄或您的配方中。
關於libdns_sd
,經過我的快速研究,該庫由 mDNS 提供。 然后,您需要添加對它的依賴項:
DEPENDS = "mdns"
如上所述,這將在配方的暫存目錄中添加 header 文件 *.a 和 *.so。
一旦正確配置了依賴項,您的編譯器需要知道包含和庫目錄在哪里,這在 Makefile 中顯然缺少,可能是因為您假設依賴項是主機工具鏈的一部分。 當您直接為主機構建時,編譯器知道在哪里可以找到包含(例如在 /usr/include 中搜索)和庫,這使得這個過程非常簡單。
但是,對於標准交叉編譯項目,在 Yocto 中,頭文件和庫位於其他位置,您需要在 Makefile 中正確指定。
在 Yocto 中管理 Makefile 項目有多種可能性,但在所有情況下,您都需要一個 Makefile,它可以接收變量(CFLAGS、LDFLAGS 等)或可選的 ZDBC11CAA5BDA99F77E6FB4DABD882E7 從編譯器調用時傳遞給編譯器。
由於您不提供 Yocto 食譜,我將舉例說明如何完成並提出一些建議。 此外,我專注於編譯方面,該示例並不完整,可能應該適用於其他構建步驟(如安裝)。
DEPENDS += "my-extralib"
# Change eventually the default source directory
S = "${WORKDIR}/git"
EXTRA_OEMAKE = " 'CC=${CC}' \
'CFLAGS=${CFLAGS} ${TARGET_CC_ARCH} -I${S}/inc -I${STAGING_DIR_TARGET}${includedir}/my-extralib-include' \
'LDFLAGS=-lrt -lpthread -lm -lmy-extralib -L${STAGING_DIR_TARGET}${libdir}/my-extralib-libdir' \
'BUILDDIR=${S}' \
'OTHER_DEFINE=${OTHER_YOCTO_VAR}' \
"
使用 EXTRA_OEMAKE 可以讓 Yocto 自動為您完成許多任務,例如配置、編譯和安裝。 如果你想覆蓋它們,這也是可能的:
do_compile() {
# modify the Makefile on the fly as an example
cp ${S}/Makefile.orig ${S}/Makefile
sed -i -e 's:= $(LDFLAGS):?= $(LDFLAGS):' ${S}/Makefile
oe_runmake SOME_OVERRIDE='some-override'
}
您還可以禁用可能未在您的情況下使用的配置步驟:
do_configure[noexec] = "1"
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.