[oe] [meta-oe][PATCH 1/2] mariadb: Upgrade to 10.3.13

Yu, Mingli mingli.yu at windriver.com
Wed Mar 6 06:04:19 UTC 2019



On 2019年03月06日 13:35, Khem Raj wrote:
> On Tue, Mar 5, 2019 at 8:23 PM Yu, Mingli <mingli.yu at windriver.com> wrote:
>>
>>
>>
>> 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?
>>
>
> No need, I have fixed it locally, there was another failure on mips
> arch which is also fixed in master-next

Got it! Thanks Khem!

>
>> 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