全志TinaLinux编译错误fatal error: unicode/ucnv.h: No such file or directory
阅读原文时间:2023年07月10日阅读:3

今天开始正式干活了

拿到一个全志Tina的板子还有一个SDK压缩包,要求我这周(只剩一天半。。。)就要把sdk编译通过并且把板子跑起来。

还特别跟我说他们试了下这个sdk编译没法通过,会报错。。。

竟然是有坑!

————————————————————————————————————————————————————————————————

准备工作:

拷贝解压SDK

阅读Guide手册(如何配置环境,如何编译,如何烧录)

读完了接下来正式开工

第一步,配置编译环境。

但是老子是ssh远程编译服务器编译,没有全向apt-install,问老大,老大说应该配好了,叫我先编译一下试试看。

应该?好吧,先略过。

第二步,编译

还好编译的时候回自动检测编译环境是否配置ok。

按照手册开始一步一步编译,问了下公司的服务器只有4核,为了不影响其他人使用,在这里只能make -j4编译。

之后就是等待结果。。同时可以去找找烧录套件准备硬件连接。

$ tar -xvf Homlet-Tina-H2_H3
$ cd Homlet-Tina-H2_H3
$ source build/envsetup.sh
$ lunch dolphin_p1-tina
$ make –j4

编译了大概13分钟之后就Error报错了!

停止编译了!

In file included from /usr/include/libxml2/libxml/parser.h:810:0,
from /usr/include/libxml2/libxml/globals.h:18,
from /usr/include/libxml2/libxml/threads.h:35,
from /usr/include/libxml2/libxml/xmlmemory.h:218,
from /usr/include/libxml2/libxml/tree.h:1307,
from mxmlds.c:22:/usr/include/libxml2/libxml/encoding.h:31:26: fatal error: unicode/ucnv.h: No such file or directory
compilation terminated.
Makefile:393: recipe for target 'mxmlds.lo' failed
make[6]: *** [mxmlds.lo] Error 1
make[6]: Leaving directory '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/compile_dir/target/libmgncs-1.2.0/src/datasource'
Makefile:624: recipe for target 'install-recursive' failed
make[5]: *** [install-recursive] Error 1
make[5]: Leaving directory '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/compile_dir/target/libmgncs-1.2.0/src'
Makefile:487: recipe for target 'install-recursive' failed
make[4]: *** [install-recursive] Error 1
make[4]: Leaving directory '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/compile_dir/target/libmgncs-1.2.0'
Makefile:95: recipe for target '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/compile_dir/target/libmgncs-1.2.0/.built' failed
make[3]: *** [/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/compile_dir/target/libmgncs-1.2.0/.built] Error 2
make[3]: Leaving directory '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/package/minigui/libmgncs'
package/Makefile:192: recipe for target 'package/minigui/libmgncs/compile' failed
make[2]: *** [package/minigui/libmgncs/compile] Error 2
make[2]: Leaving directory '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3'
package/Makefile:189: recipe for target '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/staging_dir/target/stamp/.package_compile' failed
make[1]: *** [/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/out/dolphin-p1/staging_dir/target/stamp/.package_compile] Error 2
make[1]: Leaving directory '/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3'
Build failed - please re-run with -j1 to see the real error message
/home/liuxueneng/WorkCode/Homlet-Tina-H2_H3/build/toplevel.mk:275: recipe for target 'world' failed
make: *** [world] Error 1

make failed to build some targets (12:27 (mm:ss))

看报错是在编译 libmgncs-1.2.0源码包的mxmlds.c的时候跟踪到encoding.h但是找不到被包含的头文件unicode/ucnv.h

打开mxmlds.c看一下,含有以下几个头文件其中tree.h和parser.h都包含了encoding.h

#include
#include
#include

编译该源码包的时候指向的头文件路径是 /usr/include/libxml2/libxml/encoding.h

看下头文件

/*
2 * Summary: interface for the encoding conversion functions
3 * Description: interface for the encoding conversion functions needed for
4 * XML basic encoding and iconv() support.
5 *
6 * Related specs are
7 * rfc2044 (UTF-8 and UTF-16) F. Yergeau Alis Technologies
8 * [ISO-10646] UTF-8 and UTF-16 in Annexes
9 * [ISO-8859-1] ISO Latin-1 characters codes.
10 * [UNICODE] The Unicode Consortium, "The Unicode Standard --
11 * Worldwide Character Encoding -- Version 1.0", Addison-
12 * Wesley, Volume 1, 1991, Volume 2, 1992. UTF-8 is
13 * described in Unicode Technical Report #4.
14 * [US-ASCII] Coded Character Set--7-bit American Standard Code for
15 * Information Interchange, ANSI X3.4-1986.
16 *
17 * Copy: See Copyright for the status of this software.
18 *
19 * Author: Daniel Veillard
20 */
21
22 #ifndef __XML_CHAR_ENCODING_H__
23 #define __XML_CHAR_ENCODING_H__
24
25 #include
26
27 #ifdef LIBXML_ICONV_ENABLED
28 #include
29 #endif
30 #ifdef LIBXML_ICU_ENABLED
31 #include
32 #endif
33 #ifdef __cplusplus
34 extern "C" {
35 #endif

发现里面有个宏 LIBXML_ICU_ENABLED开关控制unicode/ucnv.h的包含,控制ICU的功能是否需要enable。

现在报错找不到unicode/ucnv.h说明这个宏被人定义了,但是在sdk目录下搜索LIBXML_ICU_ENABLED 关键字的文件只有两个,其中xmlversion.h明确屏蔽了这个宏

./package/allwinner/liballwinner_tina/liballwinner/LIBRARY/EXTERNAL/include/libxml/encoding.h
./package/allwinner/liballwinner_tina/liballwinner/LIBRARY/EXTERNAL/include/libxml/xmlversion.h

/**
* LIBXML_ICU_ENABLED:
*
* Whether icu support is available
*/
#if 0
#define LIBXML_ICU_ENABLED
#endif

上面两个文件和指定目录的文件是同一个类型,只是不同版本,查看指定路径头文件/usr/include/libxml2/libxml/xmlversion.h,发现里面打开了这个宏。

/**
281 * LIBXML_ICU_ENABLED:
282 *
283 * Whether icu support is available
284 */
285 #if 1
286 #define LIBXML_ICU_ENABLED
287 #endif

原本可以在指定的头文件里屏蔽掉这个宏重新编译就可以了。

但是这个是编译服务器的系统头文件

首先没有权限修改。

其次为了编译某个项目屏蔽公用的头文件功能对别人使用会有影响。

最重要的是这个sdk编译完了要打包烧录到arm板子上,最好不要依赖牵涉宿主机上的东西,所有依赖自带并打包才更符合逻辑。

--------------------------------------------------------------------------------------------------------------------------------------------------

问题原因找到了,解决办法就是修改头文件指定目录。

现在需要找到头文件路径设置的地方进而修改。

整个sdk编译走的都是Makefile结构,头文件路径有些是从父级环境变量继承下来的,有些是子目录源码自己添加的。

查看出问题的源码Makefile发现了CPPFLAGS里面就是包含了刚才那个系统头文件目录

/usr/include/libxml2/libxml

但是改这个Makefile是没有任何意义的,因为Makefile文件是configure之后自动产生的,所以这个应该问题和configure有关

看下源码libmgncs-1.2.0目录下的configure文件(重新解压未编译过的)果然发现了里面自带的configure.as包含这个固定路径

if test "x$build_datasource_xml" = "xyes"; then
AC_DEFINE(_MGNCSDB_DATASOURCE, 1,
[Define if support datasource])
AC_DEFINE(_MGNCSDB_XML, 1,
[Define if support xml datasource])
CPPFLAGS="$CPPFLAGS -I/usr/include/libxml2"
fi

现在只要把这个头文件地址改到自己指定的libxml2目录就可以了

CPPFLAGS="$CPPFLAGS -I../../../../package/allwinner/liballwinner_tina/liballwinner/LIBRARY/EXTERNAL/include/libxml"

重新configure 编译就通过了。

接下来就是准备烧录验证硬件了。。。