簡體   English   中英

如何將 librt 和 libpthread 鏈接到 Yocto 中的新層?

[英]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 依賴概念

首先,您似乎在 Yocto 中混合了各種依賴概念:

  • IMAGE_INSTALL是一個圖像依賴項,告訴 Yocto 參數中的配方必須安裝在最終圖像中。 它應該放在圖像配方中,而不是 package 配方中。 我不認為將其添加到 package 配方中會告訴 Yocto 將此依賴項添加到配方的暫存目錄中。
  • RDEPENDS在 package 配方中使用,並告訴 Yocto 配方取決於運行時參數中的包。 然后,如果您安裝需要它們的 package,它將在最終映像中安裝所需的運行時依賴項。
    一個基本示例是包含腳本 shell 在運行時依賴於某些 shell 解釋器的配方。
  • DEPENDS也在 package 配方中使用,並告訴 Yocto 配方取決於編譯時參數中的包。 它將在配方的暫存目錄中添加 header 文件和庫。

話雖如此, libstdc++libpthreadlibrt是工具鏈的一部分,您無需為此在配方中添加顯式依賴項。 它們將毫不費力地安裝在暫存目錄或您的配方中。

關於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"

一些技巧

  • 如果你從 Yocto 開始,有很多東西要學,而且一開始很難找到如何管理所有可能性和選項。 我強烈建議您從一個簡單的 Makefile 和最少的源文件開始,以專注於 Yocto 方面。
  • 您可以在 web(也是 Yocto、Poky 基本食譜)上找到很多食譜示例,這些示例可能與您正在嘗試實現的目標很接近。 Yocto 的文檔確實很完整,但它更像是一個基礎參考。 具體的實現可以在現有的配方中找到。
  • 配方構建目錄中的臨時目錄是一個金礦,其中包含不同構建步驟的所有腳本和日志。 這是您創建食譜時首先要看的地方。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM