diff options
Diffstat (limited to 'patches/fuel-plugin-opendaylight')
-rw-r--r-- | patches/fuel-plugin-opendaylight/0001-ODL-leveldb-leveldbjni-Enable-arm64-support.patch | 121 | ||||
-rw-r--r-- | patches/fuel-plugin-opendaylight/0002-install_quagga.sh-Enable-parallel-build.patch | 28 |
2 files changed, 0 insertions, 149 deletions
diff --git a/patches/fuel-plugin-opendaylight/0001-ODL-leveldb-leveldbjni-Enable-arm64-support.patch b/patches/fuel-plugin-opendaylight/0001-ODL-leveldb-leveldbjni-Enable-arm64-support.patch deleted file mode 100644 index b307af2b..00000000 --- a/patches/fuel-plugin-opendaylight/0001-ODL-leveldb-leveldbjni-Enable-arm64-support.patch +++ /dev/null @@ -1,121 +0,0 @@ -:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: -: Copyright (c) 2017 Enea AB, Cavium and others. -: -: All rights reserved. This program and the accompanying materials -: are made available under the terms of the Apache License, Version 2.0 -: which accompanies this distribution, and is available at -: http://www.apache.org/licenses/LICENSE-2.0 -:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: -From: Florin Dumitrascu <florin.dumitrascu@enea.com> -Date: Thu, 17 Mar 2016 18:15:42 +0100 -Subject: [PATCH] ODL leveldb, leveldbjni: Enable arm64 support. - -ODL depends on a native library (leveldb). - -ODL Beryllium and Boron versions are still using a native x86 version -of this library (wrapped in leveldbjni). - -There is no upstream version of leveldbjni supporting arm64 leveldb, -so we need to compile it when deploying ODL. -This is done when running odl-install puppet manifest. - -For more info about this ODL limitation, see [1]. - -[ Alexandru.Avadanii@enea.com ] -Remove JAVA8 changes after upstream rework. -Convert puppet patching to prebuilt DEB package, as part of [2]. -Rebase for Fuel Newton. - -[ Dan.Andresan@enea.com ] -Modify Puppet recipe to restart Opendaylight service after leveldbjni -This avoids a cache corruption described in [3] -Fix leveldbjni on x86_64, since it should be silently skipped. - -[1] https://bugs.opendaylight.org/show_bug.cgi?id=3973 -[2] https://jira.opnfv.org/browse/ARMBAND-114 -[3] https://jira.opnfv.org/browse/ARMBAND-211 - -Change-Id: Ia7abf375ffd122ff0ac7b12422f64526ff2c78fd -Signed-off-by: Florin Dumitrascu <florin.dumitrascu@enea.com> -Signed-off-by: Stanislaw Kardach <stanislaw.kardach@cavium.com> -Signed-off-by: Alexandru Avadanii <Alexandru.Avadanii@enea.com> -Signed-off-by: Dan Andresan <dan.andresan@enea.com> ---- - .../puppet/modules/opendaylight/manifests/init.pp | 8 ++++++ - .../modules/opendaylight/manifests/install.pp | 3 ++ - .../modules/opendaylight/manifests/leveldbjni.pp | 32 ++++++++++++++++++++++ - 3 files changed, 43 insertions(+) - create mode 100644 deployment_scripts/puppet/modules/opendaylight/manifests/leveldbjni.pp - -diff --git a/deployment_scripts/puppet/modules/opendaylight/manifests/init.pp b/deployment_scripts/puppet/modules/opendaylight/manifests/init.pp -index 69cc23a..791ceba 100644 ---- a/deployment_scripts/puppet/modules/opendaylight/manifests/init.pp -+++ b/deployment_scripts/puppet/modules/opendaylight/manifests/init.pp -@@ -9,4 +9,12 @@ class opendaylight { - $odl_mgmt_ips = values($odl_mgmt_ips_hash) - $odl_nodes_names = keys($odl_mgmt_ips_hash) - $node_internal_address = $odl_mgmt_ips_hash["node-${node_uid}"] -+ -+ $arch = $::architecture ? { -+ 'aarch64' => $::osfamily ? { -+ 'Debian' => 'arm64', -+ default => 'aarch64', -+ }, -+ default => $::architecture, -+ } - } -diff --git a/deployment_scripts/puppet/modules/opendaylight/manifests/install.pp b/deployment_scripts/puppet/modules/opendaylight/manifests/install.pp -index 2c3d776..22ab204 100644 ---- a/deployment_scripts/puppet/modules/opendaylight/manifests/install.pp -+++ b/deployment_scripts/puppet/modules/opendaylight/manifests/install.pp -@@ -85,9 +85,12 @@ class opendaylight::install ( - value => $enabled_features, - } - -+ include opendaylight::leveldbjni -+ - Package['opendaylight'] -> - Ini_setting <||> -> - Firewall <||> -> -+ Class['opendaylight::leveldbjni'] -> - File <||> ~> - Service['opendaylight'] - } -diff --git a/deployment_scripts/puppet/modules/opendaylight/manifests/leveldbjni.pp b/deployment_scripts/puppet/modules/opendaylight/manifests/leveldbjni.pp -new file mode 100644 -index 0000000..71c3635 ---- /dev/null -+++ b/deployment_scripts/puppet/modules/opendaylight/manifests/leveldbjni.pp -@@ -0,0 +1,32 @@ -+# == Class opendaylight::leveldbjni -+# -+# Manages patching of JNI for leveldb on arm64. -+# -+# It fetches a prebuilt DEB package containing leveldbjni, -+# patched so that it's properly detected by maven on arm64 systems. -+# -+# DEB: http://linux.enea.com/mos-repos/ubuntu/9.0/ \ -+# pool/main/a/armband-odl-leveldb-fix/ -+# JIRA: https://jira.opnfv.org/browse/ARMBAND-114 -+# -+class opendaylight::leveldbjni { -+ case $::osfamily { -+ 'Debian', 'Ubuntu': {} -+ default: { -+ fail('Not supported on OS other than Debian based.') -+ } -+ } -+ -+ if $::osfamily == 'Debian' and $::opendaylight::arch == 'arm64' and ! defined(Package['armband-odl-leveldb-fix']) { -+ exec {'hotfix-odl': -+ command => 'systemctl stop opendaylight; rm -rf /opt/opendaylight/data/cache', -+ onlyif => 'test 0 -eq $(dpkg -l | grep -c armband-odl-leveldb-fix)', -+ path => ['/bin', '/usr/bin'] -+ } -+ -+ package { 'armband-odl-leveldb-fix': -+ ensure => 'present', -+ require => Exec['hotfix-odl'] -+ } -+ } -+} diff --git a/patches/fuel-plugin-opendaylight/0002-install_quagga.sh-Enable-parallel-build.patch b/patches/fuel-plugin-opendaylight/0002-install_quagga.sh-Enable-parallel-build.patch deleted file mode 100644 index 553fb7fc..00000000 --- a/patches/fuel-plugin-opendaylight/0002-install_quagga.sh-Enable-parallel-build.patch +++ /dev/null @@ -1,28 +0,0 @@ -:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: -: Copyright (c) 2017 Enea AB and others. -: -: All rights reserved. This program and the accompanying materials -: are made available under the terms of the Apache License, Version 2.0 -: which accompanies this distribution, and is available at -: http://www.apache.org/licenses/LICENSE-2.0 -:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: -From: Alexandru Avadanii <Alexandru.Avadanii@enea.com> -Date: Thu, 23 Feb 2017 23:45:41 +0000 (+0100) -Subject: install_quagga.sh: Enable parallel build - -install_quagga.sh: Enable parallel build - -Change-Id: I8b961ebacc6ab096200d1e124d8f50ed6e2b8217 -Signed-off-by: Alexandru Avadanii <Alexandru.Avadanii@enea.com> ---- - -diff --git a/pre_build_hook b/pre_build_hook -index ab8b0a6..20dd715 100755 ---- a/pre_build_hook -+++ b/pre_build_hook -@@ -78,3 +78,5 @@ sed -i 's/cd zrpcd/cd zrpcd \&\& git checkout eddf5bd6305ef52a2d39df99860c734935 - sed -i 's/quagga_110_mpbgp_capnp/95bb0f4a5/' deployment_scripts/install_quagga.sh - # pin thrift to the latest version at this point in time - sed -i 's/cd thrift/cd thrift \&\& git checkout 0.10.0/' deployment_scripts/install_quagga.sh -+# enable parallel build -+sed -i 's|make$|make -j|g' deployment_scripts/install_quagga.sh |