yocto sdk加入自定义动态库

yocto有现成的sdk配方指令,例如

bitbake xxxx-image -c populate_sdk

可生成系统默认存在的开发工具,如果想加入自定义的动态库可用如下方法

在系统中加入版本号接口,本地编写代码并确定能编译成动态库,生成动态库的makefile如下

SOURCES = fubversion.cpp
OBJS = $(patsubst %.cpp, %.o, $(SOURCES))

CFLAGS := -Wall -O3 -std=c++0x
# INC_PATH =
# LIB_PATH =

LIB = libfubversion.so

all: $(LIB)

$(OBJS): $(SOURCES)
	$(CXX) $(CFLAGS) -fpic -c $< -o $@ $(INC_PATH) $(LIB_PATH)

$(LIB): $(OBJS)
	rm -f $@ 
	$(CXX) -shared -o $@ $(OBJS) 
	rm -f $(OBJS)

tags:
	ctags -R * 

clean: 
	rm -f $(OBJS) $(TARGET) $(LIB)

然后将其放入yocto系统里,按照如下方法写bb文件,此文件调试后未整理,可能存在冗余

DESCRIPTION = "fub version library"

LICENSE = "MIT"
LIC_FILES_CHKSUM = "file://${COMMON_LICENSE_DIR}/MIT;md5=0835ade698e0bcf8506ecda2f7b4f302"
PR = "1"

SRC_URI = "file://source-code \
                file://patch \
                file://source-code/libfubversion.so"

# DEPENDS = "glib-2.0"

S = "${WORKDIR}/source-code/"

do_compile() {
        make
}

do_install() {
        install -d ${D}/usr/lib
        cp ${WORKDIR}/source-code/libfubversion.so ${WORKDIR}/source-code/libfubversion.so.${PR}
        install -m 0755 ${WORKDIR}/source-code/libfubversion.so.${PR} ${D}/usr/lib
        install -m 0755 ${WORKDIR}/source-code/libfubversion.so ${D}/usr/lib
        cd ${D}/usr/lib/
        ln -sf libfubversion.so.${PR} libfubversion.so
        install -d ${D}/usr/include
        install -m 0644 ${WORKDIR}/source-code/fubversion.h ${D}/usr/include/
}

INHIBIT_PACKAGE_STRIP = "1"
FILES_${PN} += "${libdir}/*.so"
FILES_${PN}-dbg += "${libdir}/.debug"
FILES_SOLIBSDEV = ""
INSANE_SKIP_${PN} = "dev-so"
BBCLASSEXTEND = "native nativesdk"

此处有几个关键的字段

该字段可将相关动态库生成到sdk中

BBCLASSEXTEND = "native nativesdk"

在SDK里还需要一个头文件,此处的头文件的安装不规范,但可以使用

到此,将一个包含自定义的动态库生成到sdk已经完成了,但动态库需要同时放到文件系统中,编译系统指令,如

bitbake xxxx-image

将动态库编译到文件系统规则多一些,如

其中.so为链接文件不可少,否者会提示链接文件缺失,大概如下一类错误

QA Issue: non -dev/-dbg/-nativesdk package contains symlink .so
QA Issue: -dev package contains non-symlink .so

在do_instll制作.so链接文件和对应的动态库后,不会自动将链接文件和动态库一并生成到文件系统里

在fubversion配方的image文件夹里是存在.so和动态链接文件的,但是在最终的文件系统却没有.so链接文件

这与do_package_qa一类的规则有关,解决办法

FILES_${PN} += "${libdir}/*.so"
FILES_${PN}-dbg += "${libdir}/.debug"
FILES_SOLIBSDEV = ""
INSANE_SKIP_${PN} = "dev-so"

此时才会将.so链接文件和对应的动态链接库都安装到文件系统里

上边说的头文件的问题在这里也有,就是会将头文件也安装到文件系统里,这是不需要的,以后在加入sdk头文件的安装方法

文件系统完成,系统的镜像也同步好了,测试验证

写一个测试app,makefile,读取版本号

makefile

# INCLUDE = -I $(SDK_ROOT_DIR)/usr/include
LIBS = -lversion

LDFLAGS += $(LIBS)
CPPFLAGS += $(INCLUDE)

TARGET = app_get_version
TARGET_DIR = .

SOURCES = app.cpp

OBJ_FILES = $(patsubst %.cpp, %.o, $(SOURCES))

all: check_env compile link

check_env:
	@echo "[$(TARGET)]: Build Start..."
	@mkdir -p $(TARGET_DIR)
	@echo ${CXX}

compile: $(OBJ_FILES)

link:
	@echo "[$(TARGET)]: Linking ..."
	@$(CXX) $(OBJ_FILES) $(LDFLAGS) -o $(TARGET_DIR)/$(TARGET)
	rm -f $(OBJ_FILES)
	@echo "[$(TARGET)]: Build done!"	

#complie step 1:
$(OBJ_FILES): %.o: %.cpp
	@echo "[$(TARGET)]: Compiling  $(notdir $^) ..."
	@$(CXX) -c $(CPPFLAGS) $< -o $@

clean:
	@rm -rf $(OBJ_FILES) $(TARGET_DIR)/$(TARGET)
	@echo "[$(TARGET)]: Clean Finish!"

应用程序就无需关心版本号的管理怎么实现的,通过非常简单的sdk接口获得版本号达到目的

#include 
#include 
#include 

int main ()
{
	std::string sVerBuff;
	sVerBuff.clear();
	sVerBuff = VersionInfo::GetInstance()->GetVersionInfo("ro.build.fub.version");
	printf ("%s \n", sVerBuff.c_str());
	return 0;
}

 

文中相关代码

https://download.csdn.net/download/bgk112358/10770983

 

在更新的yocto中又遇到了如下问题

do_package_qa: QA Issue: No GNU_HASH in the elf binary: '/home/qiuhui/imx8_4.16/build-mek/tmp/work/aarch64-poky-linux/fubversion/0.1-1/packages-split/fubversion/usr/lib/libfubversion.so.1' [ldflags]

可加入如下命令解决

TARGET_CC_ARCH += "${LDFLAGS}"

同时还查到如下命令,此命令未验证
ERROR_QA_remove = "ldflags"

 

你可能感兴趣的:(yocto,sdk)