[oe] [meta-oe][PATCH 1/2] mariadb: Upgrade to 10.3.13
Yu, Mingli
mingli.yu at windriver.com
Wed Mar 6 04:29:00 UTC 2019
On 2019年03月06日 02:26, Khem Raj wrote:
> On Mon, Mar 4, 2019 at 9:29 PM <mingli.yu at windriver.com> wrote:
>>
>> From: Mingli Yu <mingli.yu at windriver.com>
>>
>> Per https://mariadb.org/about/maintenance-policy/,
>> mariadb 5.5.x series only supported until next year
>> April 2020, so upgrade it to 10.3.13.
>>
>> Remove some deprecated patches, add some
>> new patches to fix build failure and rework
>> two patches to avoid fuzz warnings.
>>
>
> I think we need to add
>
> LDFLAGS += "-pthread"
>
> this helps it linking on some arches where libatomics might be
> required.
Thanks Khem! And I notice you make a patch as
http://cgit.openembedded.org/meta-openembedded/commit/?h=master-next&id=7337b759132baa7bb421fdb904e12a278dbe0662
to fix the atomics issue.
If so, do I need to resend V2 to cover the above logic as you suggested?
Thanks,
>
>> Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>> ---
>> ...ve_5.5.62.bb => mariadb-native_10.3.13.bb} | 1 +
>> meta-oe/recipes-dbs/mysql/mariadb.inc | 29 ++--
>> .../0001-disable-ucontext-on-musl.patch | 8 +-
>> .../mariadb/change-cc-to-cc-version.patch | 26 ---
>> .../configure.cmake-fix-valgrind.patch | 27 ++-
>> .../mariadb/fix-a-building-failure.patch | 16 +-
>> .../mysql/mariadb/fix-cmake-module-path.patch | 29 ----
>> .../mariadb/fix-mysqlclient-r-version.patch | 160 ------------------
>> .../mysql/mariadb/remove-bad-path.patch | 18 --
>> ...Lists.txt-fix-gen_lex_hash-not-found.patch | 65 +++++++
>> ...akeLists.txt-fix-do_populate_sysroot.patch | 34 ++++
>> .../{mariadb_5.5.62.bb => mariadb_10.3.13.bb} | 2 +-
>> 12 files changed, 145 insertions(+), 270 deletions(-)
>> rename meta-oe/recipes-dbs/mysql/{mariadb-native_5.5.62.bb => mariadb-native_10.3.13.bb} (88%)
>> delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch
>> delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch
>> delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch
>> delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch
>> create mode 100644 meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch
>> create mode 100644 meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch
>> rename meta-oe/recipes-dbs/mysql/{mariadb_5.5.62.bb => mariadb_10.3.13.bb} (88%)
>>
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb-native_5.5.62.bb b/meta-oe/recipes-dbs/mysql/mariadb-native_10.3.13.bb
>> similarity index 88%
>> rename from meta-oe/recipes-dbs/mysql/mariadb-native_5.5.62.bb
>> rename to meta-oe/recipes-dbs/mysql/mariadb-native_10.3.13.bb
>> index 4ce960d7d..e1a038dfa 100644
>> --- a/meta-oe/recipes-dbs/mysql/mariadb-native_5.5.62.bb
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb-native_10.3.13.bb
>> @@ -13,6 +13,7 @@ do_install() {
>>
>> install -d ${D}${bindir}
>> install -m 0755 sql/gen_lex_hash ${D}${bindir}/
>> + install -m 0755 sql/gen_lex_token ${D}${bindir}/
>> install -m 0755 extra/comp_err ${D}${bindir}/
>> install -m 0755 scripts/comp_sql ${D}${bindir}/
>> }
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb.inc b/meta-oe/recipes-dbs/mysql/mariadb.inc
>> index 8ca5b2ba4..65f98bd3b 100644
>> --- a/meta-oe/recipes-dbs/mysql/mariadb.inc
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb.inc
>> @@ -4,10 +4,7 @@ SECTION = "libs"
>> LICENSE = "GPLv2"
>> LIC_FILES_CHKSUM = "file://COPYING;md5=751419260aa954499f7abaabaa882bbe"
>>
>> -SRC_URI = "https://downloads.mariadb.org/f/${BP}/source/${BP}.tar.gz \
>> - file://fix-cmake-module-path.patch \
>> - file://remove-bad-path.patch \
>> - file://fix-mysqlclient-r-version.patch \
>> +SRC_URI = "https://downloads.mariadb.org/interstitial/${BPN}-${PV}/source/${BPN}-${PV}.tar.gz \
>> file://my.cnf \
>> file://mysqld.service \
>> file://install_db.service \
>> @@ -15,11 +12,12 @@ SRC_URI = "https://downloads.mariadb.org/f/${BP}/source/${BP}.tar.gz \
>> file://mysql-systemd-start \
>> file://configure.cmake-fix-valgrind.patch \
>> file://fix-a-building-failure.patch \
>> - file://change-cc-to-cc-version.patch \
>> + file://support-files-CMakeLists.txt-fix-do_populate_sysroot.patch \
>> + file://sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch \
>> file://0001-disable-ucontext-on-musl.patch \
>> "
>> -SRC_URI[md5sum] = "6375d577e9539b839f44d857e70f82b9"
>> -SRC_URI[sha256sum] = "56a365af71b8a9ec8bfee0801e2dec95011da8ee7507986ca329be11296411db"
>> +SRC_URI[md5sum] = "603ce42e35b9a688f2cca05275acb5cb"
>> +SRC_URI[sha256sum] = "b2aa857ef5b84f85a7ea60a1eac7b34c0ca5151c71a0d44ce2d7fb028d71459a"
>>
>> UPSTREAM_CHECK_URI = "https://github.com/MariaDB/server/releases"
>>
>> @@ -120,6 +118,11 @@ do_compile_prepend_class-target () {
>> echo "#endif" >>${B}/include/openssl/kssl.h
>> fi
>> fi
>> + # workaround to handle out-of-source build from source package
>> + yacc_files="sql_yacc.hh sql_yacc.cc sql_yacc_ora.hh sql_yacc_ora.cc"
>> + for yacc_file in ${yacc_files}; do
>> + cp ${S}/sql/${yacc_file} ${B}/sql/${yacc_file}
>> + done
>> }
>>
>> SYSROOT_PREPROCESS_FUNCS += "mariadb_sysroot_preprocess"
>> @@ -181,13 +184,13 @@ RDEPENDS_${PN}-client = "perl perl-module-getopt-long perl-module-file-temp \
>> RDEPENDS_${PN}-server = "perl perl-module-getopt-long perl-module-data-dumper \
>> perl-module-file-basename perl-module-file-path perl-module-sys-hostname \
>> perl-module-file-copy perl-module-file-temp perl-module-posix \
>> - ${PN}-client libdbi-perl libdbd-mysql-perl"
>> + ${PN}-client ${PN}-setupdb libdbi-perl libdbd-mysql-perl"
>> RDEPENDS_${PN}-leftovers = "perl perl-module-cwd perl-module-benchmark perl-module-getopt-long \
>> perl-module-posix perl-module-data-dumper perl-module-sigtrap perl-module-threads \
>> perl-module-threads-shared perl-module-io-socket perl-module-sys-hostname perl-module-file-copy \
>> perl-module-file-spec perl-module-file-find perl-module-file-basename perl-module-file-path \
>> perl-module-constant perl-module-lib perl-module-file-temp perl-module-file-spec-functions \
>> - perl-module-io-socket-inet perl-module-io-select"
>> + perl-module-io-socket-inet perl-module-io-select bash"
>> RDEPENDS_${PN}-setupdb = "coreutils"
>>
>> # Allow old code to link to the backward compatible library
>> @@ -195,10 +198,12 @@ RDEPENDS_libmysqlclient-dev = "libmysqlclient-r-dev"
>>
>> FILES_libmysqlclient = "\
>> ${libdir}/libmysqlclient.so.* \
>> + ${libdir}/libmariadb.so.* \
>> ${sysconfdir}/my.cnf.d/client.cnf"
>> FILES_libmysqlclient-dev = " \
>> ${includedir}/mysql/ \
>> ${libdir}/libmysqlclient.so \
>> + ${libdir}/libmariadb.so \
>> ${sysconfdir}/aclocal \
>> ${bindir}/mysql_config"
>> FILES_libmysqlclient-staticdev = "\
>> @@ -215,9 +220,11 @@ FILES_libmysqlclient-r-dev = "\
>> FILES_libmysqlclient-r-staticdev = "${libdir}/libmysqlclient_r.a"
>>
>> FILES_libmysqld = "\
>> - ${libdir}/libmysqld.so.*"
>> + ${libdir}/libmysqld.so.* \
>> + ${libdir}/libmariadbd.so.*"
>> FILES_libmysqld-dev = "\
>> - ${libdir}/libmysqld.so"
>> + ${libdir}/libmysqld.so \
>> + ${libdir}/libmariadbd.so"
>>
>> FILES_${PN}-client = "\
>> ${bindir}/myisam_ftdump \
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch b/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch
>> index 60e9199f9..daf2432a5 100644
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch
>> @@ -1,4 +1,4 @@
>> -From 5bc3e7ef9700d12054e0125a126f1bb093f01ef9 Mon Sep 17 00:00:00 2001
>> +From b658bdb38b7ff6a78915fd0ac390fc224e4006cb Mon Sep 17 00:00:00 2001
>> From: Khem Raj <raj.khem at gmail.com>
>> Date: Sun, 26 Mar 2017 14:30:33 -0700
>> Subject: [PATCH] disable ucontext on musl
>> @@ -6,12 +6,13 @@ Subject: [PATCH] disable ucontext on musl
>> musl does not have *contex() APIs even though it has ucontext.h header
>>
>> Signed-off-by: Khem Raj <raj.khem at gmail.com>
>> +
>> ---
>> include/my_context.h | 2 +-
>> 1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/include/my_context.h b/include/my_context.h
>> -index dd44103..9b28c17 100644
>> +index ea0e3496..4c9b37dc 100644
>> --- a/include/my_context.h
>> +++ b/include/my_context.h
>> @@ -31,7 +31,7 @@
>> @@ -23,6 +24,3 @@ index dd44103..9b28c17 100644
>> #define MY_CONTEXT_USE_UCONTEXT
>> #else
>> #define MY_CONTEXT_DISABLE
>> ---
>> -2.12.1
>> -
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch b/meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch
>> deleted file mode 100644
>> index 02bda24f7..000000000
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch
>> +++ /dev/null
>> @@ -1,26 +0,0 @@
>> -mariadb: replace the CC with CC_VERSION and CXX with CXX_VERSION
>> -
>> -mysqlbug.sh is a bug report script. It makes a report with the build information,
>> -including gcc version. The CC is the local path of gcc, which is useless for bug
>> -report, and the path may expose private information, so change it to CC_VERSION.
>> -
>> -Upstream-Status: Pending
>> -
>> -Signed-off-by: Yue Tao <Yue.Tao at windriver.com>
>> -Signed-off-by: Wenzong Fan <wenzong.fan at windriver.com>
>> -================================
>> -diff --git a/scripts/mysqlbug.sh.old b/scripts/mysqlbug.sh
>> -index e9df210..d4b8d53 100644
>> ---- a/scripts/mysqlbug.sh.old
>> -+++ b/scripts/mysqlbug.sh
>> -@@ -24,8 +24,8 @@ VERSION="@VERSION@@MYSQL_SERVER_SUFFIX@"
>> - COMPILATION_COMMENT="@COMPILATION_COMMENT@"
>> - BUGmysql="maria-developers at lists.launchpad.net"
>> - # This is set by configure
>> --COMP_CALL_INFO="CC='@SAVE_CC@' CFLAGS='@SAVE_CFLAGS@' CXX='@SAVE_CXX@' CXXFLAGS='@SAVE_CXXFLAGS@' LDFLAGS='@SAVE_LDFLAGS@' ASFLAGS='@SAVE_ASFLAGS@'"
>> --COMP_RUN_INFO="CC='@CC@' CFLAGS='@CFLAGS@' CXX='@CXX@' CXXFLAGS='@CXXFLAGS@' LDFLAGS='@LDFLAGS@' ASFLAGS='@ASFLAGS@'"
>> -+COMP_CALL_INFO="CC='@CC_VERSION@' CFLAGS='@SAVE_CFLAGS@' CXX='@CXX_VERSION@' CXXFLAGS='@SAVE_CXXFLAGS@' LDFLAGS='@SAVE_LDFLAGS@' ASFLAGS='@SAVE_ASFLAGS@'"
>> -+COMP_RUN_INFO="CC='@CC_VERSION@' CFLAGS='@CFLAGS@' CXX='@CXX_VERSION@' CXXFLAGS='@CXXFLAGS@' LDFLAGS='@LDFLAGS@' ASFLAGS='@ASFLAGS@'"
>> - CONFIGURE_LINE="@CONF_COMMAND@"
>> -
>> - LIBC_INFO=""
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch b/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch
>> index e97def602..ac9427958 100644
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch
>> @@ -1,6 +1,6 @@
>> -From 5effba0d7d47071a3f1bca56823190d5a95bb1a6 Mon Sep 17 00:00:00 2001
>> +From 24e2b0edc2612acefcc48414bb6f0aeb086061a9 Mon Sep 17 00:00:00 2001
>> From: Jackie Huang <jackie.huang at windriver.com>
>> -Date: Wed, 12 Nov 2014 03:09:10 -0500
>> +Date: Tue, 26 Feb 2019 23:57:06 -0800
>> Subject: [PATCH] configure.cmake: fix valgrind
>>
>> Check valgrind headers only if WITH_VALGRIND is set.
>> @@ -15,27 +15,26 @@ PACKAGECONFIG to decide if valgrind is needed or not.
>> Upstream-Status: Inappropriate [oe specific]
>>
>> Signed-off-by: Jackie Huang <jackie.huang at windriver.com>
>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>> +
>> ---
>> - configure.cmake | 4 ++--
>> - 1 file changed, 2 insertions(+), 2 deletions(-)
>> + configure.cmake | 5 ++---
>> + 1 file changed, 2 insertions(+), 3 deletions(-)
>>
>> diff --git a/configure.cmake b/configure.cmake
>> -index 0bd7bbe..51a098f 100644
>> +index 3cfc4b31..d017b3b3 100644
>> --- a/configure.cmake
>> +++ b/configure.cmake
>> -@@ -1047,10 +1047,10 @@ MARK_AS_ADVANCED(WITH_ATOMIC_LOCKS MY_ATOMIC_MODE_RWLOCK MY_ATOMIC_MODE_DUMMY)
>> +@@ -930,10 +930,9 @@ HAVE_GCC_C11_ATOMICS)
>>
>> IF(WITH_VALGRIND)
>> SET(HAVE_valgrind 1)
>> -+ CHECK_INCLUDE_FILES("valgrind/memcheck.h;valgrind/valgrind.h"
>> -+ HAVE_VALGRIND)
>> - ENDIF()
>> -
>> +-ENDIF()
>> +-
>> -CHECK_INCLUDE_FILES("valgrind/memcheck.h;valgrind/valgrind.h"
>> -- HAVE_VALGRIND)
>> ++ CHECK_INCLUDE_FILES("valgrind/memcheck.h;valgrind/valgrind.h"
>> + HAVE_VALGRIND_MEMCHECK_H)
>> ++ENDIF()
>>
>> #--------------------------------------------------------------------
>> # Check for IPv6 support
>> ---
>> -2.0.0
>> -
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch b/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch
>> index 0c4e10237..9149ee21f 100644
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch
>> @@ -1,4 +1,7 @@
>> -[PATCH] fix a building failure
>> +From 1b2b6a61c9f82157cd2e0c3744f6c07e07aeb0bd Mon Sep 17 00:00:00 2001
>> +From: Mingli Yu <mingli.yu at windriver.com>
>> +Date: Mon, 4 Mar 2019 01:11:30 -0800
>> +Subject: [PATCH] fix a building failure
>>
>> Upstream-Status: Inappropriate [configuration]
>>
>> @@ -6,17 +9,18 @@ building failed since native does not generate import_executables.cmake
>> In fact, our building system will export the needed commands
>>
>> Signed-off-by: Roy Li <rongqing.li at windriver.com>
>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>> ---
>> CMakeLists.txt | 5 -----
>> 1 file changed, 5 deletions(-)
>>
>> diff --git a/CMakeLists.txt b/CMakeLists.txt
>> -index c1ce1c5..83b3a7e 100644
>> +index fc30750..4f9110e 100644
>> --- a/CMakeLists.txt
>> +++ b/CMakeLists.txt
>> -@@ -350,11 +350,6 @@ MYSQL_CHECK_READLINE()
>> +@@ -347,11 +347,6 @@ CHECK_PCRE()
>>
>> - CHECK_JEMALLOC()
>> + CHECK_SYSTEMD()
>>
>> -IF(CMAKE_CROSSCOMPILING)
>> - SET(IMPORT_EXECUTABLES "IMPORTFILE-NOTFOUND" CACHE FILEPATH "Path to import_executables.cmake from a native build")
>> @@ -24,8 +28,8 @@ index c1ce1c5..83b3a7e 100644
>> -ENDIF()
>> -
>> #
>> - # Setup maintainer mode options by the end. Platform checks are
>> + # Setup maintainer mode options. Platform checks are
>> # not run with the warning options as to not perturb fragile checks
>> --
>> -1.9.1
>> +2.17.1
>>
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch b/meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch
>> deleted file mode 100644
>> index 8d9f558d0..000000000
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch
>> +++ /dev/null
>> @@ -1,29 +0,0 @@
>> -Avoid CMAKE_MODULE_PATH being overwritten
>> -
>> -OE-Core's setting of CMAKE_MODULE_PATH stomps on MariaDB's value unless
>> -we set it after setting the project name.
>> -
>> -Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
>> -
>> -Upstream-Status: Inappropriate [working around OE-Core bug]
>> -
>> ---- mariadb/CMakeLists.txt 2014-07-17 11:01:07.676353047 +0100
>> -+++ mariadb/CMakeLists.txt 2014-07-17 11:01:31.299353107 +0100
>> -@@ -28,8 +28,6 @@
>> -
>> - MESSAGE(STATUS "Running cmake version ${CMAKE_VERSION}")
>> -
>> --SET(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/cmake)
>> --
>> - # Distinguish between community and non-community builds, with the
>> - # default being a community build. This does not impact the feature
>> - # set that will be compiled in; it's merely provided as a hint to
>> -@@ -77,6 +75,8 @@
>> - ENDIF()
>> - PROJECT(${MYSQL_PROJECT_NAME})
>> -
>> -+SET(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/cmake)
>> -+
>> - IF(BUILD_CONFIG)
>> - INCLUDE(
>> - ${CMAKE_SOURCE_DIR}/cmake/build_configurations/${BUILD_CONFIG}.cmake)
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch b/meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch
>> deleted file mode 100644
>> index a519e4292..000000000
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch
>> +++ /dev/null
>> @@ -1,160 +0,0 @@
>> -From 6db2a606196fb38a6d106dc409eee1cb9a40a440 Mon Sep 17 00:00:00 2001
>> -From: Tor Didriksen <tor.didriksen at oracle.com>
>> -Date: Mon, 24 Jun 2013 17:15:35 +0200
>> -Subject: [PATCH] Bug#16809055 MYSQL 5.6 AND 5.7 STILL USE LIBMYSQLCLIENT.SO.18
>> -
>> -With this patch, the libmysql/ directory contains:
>> -libmysqlclient.a
>> -libmysqlclient_r.a -> libmysqlclient.a
>> -libmysqlclient_r.so -> libmysqlclient.so*
>> -libmysqlclient_r.so.18 -> libmysqlclient.so.18*
>> -libmysqlclient_r.so.18.1.0 -> libmysqlclient.so.18.1.0*
>> -libmysqlclient.so -> libmysqlclient.so.18*
>> -libmysqlclient.so.18 -> libmysqlclient.so.18.1.0*
>> -libmysqlclient.so.18.1.0*
>> -
>> -This fixes libmysqlclient_r symlinks pointing to the unversioned
>> -libmysqlclient.so symlink (leading to package QA errors since the
>> -libmysqlclient-r package ends up depending on libmysqlclient-dev).
>> -
>> -Borrowed from MySQL 5.6 tree at https://github.com/percona/mysql/
>> -
>> -Upstream-Status: Pending
>> -
>> -Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
>> -
>> ----
>> - cmake/install_macros.cmake | 25 +++++++++++++++----------
>> - libmysql/CMakeLists.txt | 34 +++++++++++++++++++++++++++-------
>> - 2 files changed, 42 insertions(+), 17 deletions(-)
>> -
>> -diff --git a/cmake/install_macros.cmake b/cmake/install_macros.cmake
>> -index b8efdf8..a0d0e68 100644
>> ---- a/cmake/install_macros.cmake
>> -+++ b/cmake/install_macros.cmake
>> -@@ -1,4 +1,4 @@
>> --# Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
>> -+# Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved.
>> - #
>> - # This program is free software; you can redistribute it and/or modify
>> - # it under the terms of the GNU General Public License as published by
>> -@@ -167,28 +167,33 @@ ENDFUNCTION()
>> -
>> -
>> - # Install symbolic link to CMake target.
>> --# the link is created in the same directory as target
>> --# and extension will be the same as for target file.
>> --MACRO(INSTALL_SYMLINK linkname target destination component)
>> -+# We do 'cd path; ln -s target_name link_name'
>> -+# We also add an INSTALL target for "${path}/${link_name}"
>> -+MACRO(INSTALL_SYMLINK target target_name link_name destination component)
>> - IF(UNIX)
>> - GET_TARGET_PROPERTY(location ${target} LOCATION)
>> - GET_FILENAME_COMPONENT(path ${location} PATH)
>> -- GET_FILENAME_COMPONENT(name ${location} NAME)
>> -- SET(output ${path}/${linkname})
>> -+ MESSAGE(STATUS "target ${target}")
>> -+ MESSAGE(STATUS "link_name ${link_name}")
>> -+ MESSAGE(STATUS "target_name ${target_name}")
>> -+ MESSAGE(STATUS "path ${path}")
>> -+ MESSAGE(STATUS "")
>> -+
>> -+ SET(output ${path}/${link_name})
>> - ADD_CUSTOM_COMMAND(
>> - OUTPUT ${output}
>> - COMMAND ${CMAKE_COMMAND} ARGS -E remove -f ${output}
>> - COMMAND ${CMAKE_COMMAND} ARGS -E create_symlink
>> -- ${name}
>> -- ${linkname}
>> -+ ${target_name}
>> -+ ${link_name}
>> - WORKING_DIRECTORY ${path}
>> - DEPENDS ${target}
>> - )
>> -
>> -- ADD_CUSTOM_TARGET(symlink_${linkname}
>> -+ ADD_CUSTOM_TARGET(symlink_${link_name}
>> - ALL
>> - DEPENDS ${output})
>> -- SET_TARGET_PROPERTIES(symlink_${linkname} PROPERTIES CLEAN_DIRECT_OUTPUT 1)
>> -+ SET_TARGET_PROPERTIES(symlink_${link_name} PROPERTIES CLEAN_DIRECT_OUTPUT 1)
>> - IF(CMAKE_GENERATOR MATCHES "Xcode")
>> - # For Xcode, replace project config with install config
>> - STRING(REPLACE "${CMAKE_CFG_INTDIR}"
>> -diff --git a/libmysql/CMakeLists.txt b/libmysql/CMakeLists.txt
>> -index be5760f..96286ff 100644
>> ---- a/libmysql/CMakeLists.txt
>> -+++ b/libmysql/CMakeLists.txt
>> -@@ -433,6 +433,12 @@ IF(MSVC)
>> - INSTALL_DEBUG_TARGET(clientlib DESTINATION ${INSTALL_LIBDIR}/debug)
>> - ENDIF()
>> -
>> -+MACRO(GET_TARGET_NAME target out_name)
>> -+ GET_TARGET_PROPERTY(location ${target} LOCATION)
>> -+ GET_FILENAME_COMPONENT(name ${location} NAME)
>> -+ SET(${out_name} ${name})
>> -+ENDMACRO()
>> -+
>> - IF(UNIX)
>> - MACRO(GET_VERSIONED_LIBNAME LIBNAME EXTENSION VERSION OUTNAME)
>> - SET(DOT_VERSION ".${VERSION}")
>> -@@ -445,7 +451,13 @@ IF(UNIX)
>> - SET(${OUTNAME} ${LIBNAME}${EXTENSION}${DOT_VERSION})
>> - ENDIF()
>> - ENDMACRO()
>> -- INSTALL_SYMLINK(${CMAKE_STATIC_LIBRARY_PREFIX}mysqlclient_r.a mysqlclient ${INSTALL_LIBDIR} Development)
>> -+ENDIF()
>> -+
>> -+IF(UNIX)
>> -+ GET_TARGET_NAME(mysqlclient lib_name)
>> -+ INSTALL_SYMLINK(mysqlclient
>> -+ ${lib_name} ${CMAKE_STATIC_LIBRARY_PREFIX}mysqlclient_r.a
>> -+ ${INSTALL_LIBDIR} Development)
>> - ENDIF()
>> -
>> - IF(NOT DISABLE_SHARED)
>> -@@ -456,10 +468,9 @@ IF(NOT DISABLE_SHARED)
>> - # libtool compatability
>> - IF(CMAKE_SYSTEM_NAME MATCHES "FreeBSD" OR APPLE)
>> - SET(OS_SHARED_LIB_VERSION "${SHARED_LIB_MAJOR_VERSION}")
>> -- ELSEIF(CMAKE_SYSTEM_NAME MATCHES "HP-UX")
>> -- SET(OS_SHARED_LIB_VERSION "${SHARED_LIB_MAJOR_VERSION}.0")
>> - ELSE()
>> -- SET(OS_SHARED_LIB_VERSION "${SHARED_LIB_MAJOR_VERSION}.0.0")
>> -+ SET(OS_SHARED_LIB_VERSION
>> -+ "${SHARED_LIB_MAJOR_VERSION}.${SHARED_LIB_MINOR_VERSION}.0")
>> - ENDIF()
>> - # Name of shared library is mysqlclient on Unix
>> - SET_TARGET_PROPERTIES(libmysql PROPERTIES
>> -@@ -482,8 +493,13 @@ IF(NOT DISABLE_SHARED)
>> - "${CMAKE_SHARED_LIBRARY_SUFFIX}"
>> - ""
>> - linkname)
>> -- INSTALL_SYMLINK(${linkname} libmysql ${INSTALL_LIBDIR} SharedLibraries)
>> -- SET(OS_SHARED_LIB_SYMLINKS "${SHARED_LIB_MAJOR_VERSION}" "${OS_SHARED_LIB_VERSION}")
>> -+ GET_TARGET_NAME(libmysql lib_name)
>> -+ GET_FILENAME_COMPONENT(lib_name_we ${lib_name} NAME_WE)
>> -+ INSTALL_SYMLINK(libmysql
>> -+ ${lib_name} ${linkname}
>> -+ ${INSTALL_LIBDIR} SharedLibraries)
>> -+ SET(OS_SHARED_LIB_SYMLINKS
>> -+ "${SHARED_LIB_MAJOR_VERSION}" "${OS_SHARED_LIB_VERSION}")
>> - LIST(REMOVE_DUPLICATES OS_SHARED_LIB_SYMLINKS)
>> - FOREACH(ver ${OS_SHARED_LIB_SYMLINKS})
>> - GET_VERSIONED_LIBNAME(
>> -@@ -491,7 +507,11 @@ IF(NOT DISABLE_SHARED)
>> - "${CMAKE_SHARED_LIBRARY_SUFFIX}"
>> - "${ver}"
>> - linkname)
>> -- INSTALL_SYMLINK(${linkname} libmysql ${INSTALL_LIBDIR} SharedLibraries)
>> -+ GET_VERSIONED_LIBNAME(
>> -+ ${lib_name_we} "${CMAKE_SHARED_LIBRARY_SUFFIX}" "${ver}" lib_name_ver)
>> -+ INSTALL_SYMLINK(libmysql
>> -+ ${lib_name_ver} ${linkname}
>> -+ ${INSTALL_LIBDIR} SharedLibraries)
>> - ENDFOREACH()
>> - ENDIF()
>> - ENDIF()
>> ---
>> -2.0.3
>> -
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch b/meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch
>> deleted file mode 100644
>> index ff26b0b86..000000000
>> --- a/meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch
>> +++ /dev/null
>> @@ -1,18 +0,0 @@
>> -Remove host path from include directories
>> -
>> -Naturally this breaks cross-compilation if present.
>> -
>> -Upstream-Status: Pending
>> -
>> -Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
>> -
>> ---- mariadb-5.5.38/storage/tokudb/ft-index/CMakeLists.txt 2014-07-17 14:37:04.529327998 +0100
>> -+++ mariadb-5.5.38/storage/tokudb/ft-index/CMakeLists.txt 2014-07-17 14:43:56.991337895 +0100
>> -@@ -39,7 +39,6 @@
>> -
>> - ## default includes and libraries
>> - include_directories(SYSTEM
>> -- /usr/local/include
>> - ${ZLIB_INCLUDE_DIRS}
>> - )
>> -
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch b/meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch
>> new file mode 100644
>> index 000000000..afc1be47b
>> --- /dev/null
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch
>> @@ -0,0 +1,65 @@
>> +From 796464015bffe6e0beca9e1c355b223512803c3e Mon Sep 17 00:00:00 2001
>> +From: Mingli Yu <mingli.yu at windriver.com>
>> +Date: Wed, 27 Feb 2019 23:01:00 -0800
>> +Subject: [PATCH] sql/CMakeLists.txt: fix gen_lex_hash not found
>> +
>> +Fix the below do_compile issue in cross-compiling env.
>> +| make[2]: *** No rule to make target '/build/tmp/work/aarch64-poky-linux/mariadb/10.3.13-r0/mariadb-10.3.13/sql/gen_lex_hash', needed by 'sql/lex_hash.h'. Stop.
>> +| make[2]: *** No rule to make target '/build/tmp/work/aarch64-poky-linux/mariadb/10.3.13-r0/mariadb-10.3.13/sql/gen_lex_token', needed by 'sql/lex_token.h'. Stop.
>> +
>> +Upstream-Status: Inappropriate [oe build specific]
>> +
>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>> +
>> +---
>> + sql/CMakeLists.txt | 30 ++++++++++++++++++++----------
>> + 1 file changed, 20 insertions(+), 10 deletions(-)
>> +
>> +diff --git a/sql/CMakeLists.txt b/sql/CMakeLists.txt
>> +index c6910f46..bf51f4cb 100644
>> +--- a/sql/CMakeLists.txt
>> ++++ b/sql/CMakeLists.txt
>> +@@ -50,11 +50,16 @@ ${WSREP_INCLUDES}
>> +
>> +
>> +
>> +-ADD_CUSTOM_COMMAND(
>> +- OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_token.h
>> +- COMMAND gen_lex_token > lex_token.h
>> +- DEPENDS gen_lex_token
>> +-)
>> ++IF(NOT CMAKE_CROSSCOMPILING)
>> ++ ADD_CUSTOM_COMMAND(
>> ++ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_token.h
>> ++ COMMAND gen_lex_token > lex_token.h
>> ++ DEPENDS gen_lex_token)
>> ++ELSE()
>> ++ ADD_CUSTOM_COMMAND(
>> ++ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_token.h
>> ++ COMMAND gen_lex_token > lex_token.h)
>> ++ENDIF()
>> +
>> + ADD_DEFINITIONS(-DMYSQL_SERVER -DHAVE_EVENT_SCHEDULER)
>> +
>> +@@ -370,11 +375,16 @@ IF(NOT CMAKE_CROSSCOMPILING)
>> + ADD_EXECUTABLE(gen_lex_hash gen_lex_hash.cc)
>> + ENDIF()
>> +
>> +-ADD_CUSTOM_COMMAND(
>> +- OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_hash.h
>> +- COMMAND gen_lex_hash > lex_hash.h
>> +- DEPENDS gen_lex_hash
>> +-)
>> ++IF(NOT CMAKE_CROSSCOMPILING)
>> ++ ADD_CUSTOM_COMMAND(
>> ++ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_hash.h
>> ++ COMMAND gen_lex_hash > lex_hash.h
>> ++ DEPENDS gen_lex_hash)
>> ++ELSE()
>> ++ ADD_CUSTOM_COMMAND(
>> ++ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_hash.h
>> ++ COMMAND gen_lex_hash > lex_hash.h)
>> ++ENDIF()
>> +
>> + MYSQL_ADD_EXECUTABLE(mysql_tzinfo_to_sql tztime.cc COMPONENT Server)
>> + SET_TARGET_PROPERTIES(mysql_tzinfo_to_sql PROPERTIES COMPILE_FLAGS "-DTZINFO2SQL")
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch b/meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch
>> new file mode 100644
>> index 000000000..4f9a4e9b0
>> --- /dev/null
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch
>> @@ -0,0 +1,34 @@
>> +From 4ac5b555d058d4d489f25a3806a787b7b2465d09 Mon Sep 17 00:00:00 2001
>> +From: Mingli Yu <mingli.yu at windriver.com>
>> +Date: Wed, 27 Feb 2019 22:41:26 -0800
>> +Subject: [PATCH] support-files/CMakeLists.txt: fix do_populate_sysroot issue
>> +
>> +Comment out the logic which for suse as it introduces
>> +below do_populate_sysroot error:
>> +ERROR: mariadb-native-10.3.13-r0 do_populate_sysroot: sstate found an absolute path symlink /build/tmp/work/x86_64-linux/mariadb-native/10.3.13-r0/sysroot-destdir/build/tmp/work/x86_64-linux/mariadb-native/10.3.13-r0/recipe-sysroot-native/usr/sbin/rcmysql pointing at /build/tmp/work/x86_64-linux/mariadb-native/10.3.13-r0/recipe-sysroot-native/etc/init.d/mysql. Please replace this with a relative link.
>> +
>> +Upstream-Status: Inappropriate[oe build specific]
>> +
>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>> +
>> +---
>> + support-files/CMakeLists.txt | 7 -------
>> + 1 file changed, 7 deletions(-)
>> +
>> +diff --git a/support-files/CMakeLists.txt b/support-files/CMakeLists.txt
>> +index b5767432..56733de1 100644
>> +--- a/support-files/CMakeLists.txt
>> ++++ b/support-files/CMakeLists.txt
>> +@@ -165,12 +165,5 @@ IF(UNIX)
>> + INSTALL(FILES rpm/enable_encryption.preset DESTINATION ${INSTALL_SYSCONF2DIR}
>> + COMPONENT IniFiles)
>> + ENDIF()
>> +-
>> +- # This is for SuSE:
>> +- INSTALL(CODE "EXECUTE_PROCESS(COMMAND ${CMAKE_COMMAND} -E create_symlink
>> +- ${INSTALL_SYSCONFDIR}/init.d/mysql
>> +- ${INSTALL_SBINDIR}/rcmysql
>> +- WORKING_DIRECTORY \$ENV{DESTDIR}${prefix})"
>> +- COMPONENT SupportFiles)
>> + ENDIF(INSTALL_SYSCONFDIR)
>> + ENDIF()
>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb_5.5.62.bb b/meta-oe/recipes-dbs/mysql/mariadb_10.3.13.bb
>> similarity index 88%
>> rename from meta-oe/recipes-dbs/mysql/mariadb_5.5.62.bb
>> rename to meta-oe/recipes-dbs/mysql/mariadb_10.3.13.bb
>> index d7895732a..4782f2b84 100644
>> --- a/meta-oe/recipes-dbs/mysql/mariadb_5.5.62.bb
>> +++ b/meta-oe/recipes-dbs/mysql/mariadb_10.3.13.bb
>> @@ -2,7 +2,7 @@ require mariadb.inc
>>
>> EXTRA_OECMAKE += "-DSTACK_DIRECTION=-1"
>>
>> -DEPENDS += "mariadb-native ncurses zlib readline libaio libevent"
>> +DEPENDS += "mariadb-native bison-native openssl ncurses zlib readline libaio libevent"
>>
>> PROVIDES += "mysql5 libmysqlclient"
>>
>> --
>> 2.17.1
>>
>
More information about the Openembedded-devel
mailing list