Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 1 | project( |
| 2 | 'openpower-proc-control', |
| 3 | 'cpp', |
| 4 | default_options: [ |
| 5 | 'warning_level=3', |
| 6 | 'werror=true', |
Patrick Williams | 9e178b7 | 2021-10-06 15:33:36 -0500 | [diff] [blame] | 7 | 'cpp_std=c++20', |
Brad Bishop | f38b35e | 2020-11-08 10:42:34 -0500 | [diff] [blame] | 8 | 'buildtype=debugoptimized', |
| 9 | 'b_ndebug=if-release', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 10 | ], |
| 11 | license: 'Apache-2.0', |
| 12 | version: '1.0', |
Patrick Williams | 9e178b7 | 2021-10-06 15:33:36 -0500 | [diff] [blame] | 13 | meson_version: '>=0.57.0', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 14 | ) |
| 15 | add_project_arguments('-Wno-psabi', language: 'cpp') |
| 16 | |
Patrick Williams | 9e178b7 | 2021-10-06 15:33:36 -0500 | [diff] [blame] | 17 | if get_option('cpp_std') != 'c++20' |
| 18 | error('This project requires c++20') |
Brad Bishop | f38b35e | 2020-11-08 10:42:34 -0500 | [diff] [blame] | 19 | endif |
| 20 | |
| 21 | if(get_option('buildtype') == 'minsize') |
| 22 | add_project_arguments('-DNDEBUG', language : 'cpp') |
| 23 | endif |
| 24 | |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 25 | cxx = meson.get_compiler('cpp') |
| 26 | |
| 27 | extra_sources = [] |
| 28 | extra_dependencies = [] |
| 29 | extra_unit_files = [] |
| 30 | |
Jayanth Othayoth | 3840547 | 2021-07-26 06:16:44 -0500 | [diff] [blame] | 31 | # Configuration header file(config.h) generation |
| 32 | conf_data = configuration_data() |
| 33 | |
| 34 | conf_data.set_quoted('DEVTREE_EXPORT_FILTER_FILE', get_option('DEVTREE_EXPORT_FILTER_FILE'), |
| 35 | description : 'Path to the phal devtree export filter file' |
| 36 | ) |
| 37 | |
| 38 | conf_data.set_quoted('DEVTREE_EXP_FILE', get_option('DEVTREE_EXP_FILE'), |
| 39 | description : 'Path to the devtree export copy file' |
| 40 | ) |
| 41 | |
Jayanth Othayoth | 94fc70c | 2021-11-25 08:18:03 -0600 | [diff] [blame] | 42 | conf_data.set_quoted('CEC_DEVTREE_RW_PATH', get_option('CEC_DEVTREE_RW_PATH'), |
| 43 | description : 'Path to the devtree file r/w version' |
| 44 | ) |
| 45 | |
| 46 | conf_data.set_quoted('CEC_DEVTREE_RO_PATH', get_option('CEC_DEVTREE_RO_PATH'), |
| 47 | description : 'Path to the devtree file read only version' |
| 48 | ) |
| 49 | |
| 50 | conf_data.set_quoted('CEC_INFODB_PATH', get_option('CEC_INFODB_PATH'), |
| 51 | description : 'Path to the devtree attributes based database path' |
| 52 | ) |
| 53 | |
| 54 | conf_data.set_quoted('DEVTREE_REINIT_ATTRS_LIST', get_option('DEVTREE_REINIT_ATTRS_LIST'), |
| 55 | description : 'Path to the phal devtree reinit attribute list file' |
| 56 | ) |
| 57 | |
Jayanth Othayoth | 3840547 | 2021-07-26 06:16:44 -0500 | [diff] [blame] | 58 | configure_file(configuration : conf_data, |
| 59 | output : 'config.h' |
| 60 | ) |
| 61 | |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 62 | unit_subs = configuration_data() |
Brad Bishop | a5b4b1b | 2020-11-08 12:14:03 -0500 | [diff] [blame] | 63 | unit_subs.set('bindir', join_paths(get_option('prefix'), get_option('bindir'))) |
| 64 | unit_subs.set('ENABLE_PHAL_TRUE', '#') |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 65 | |
| 66 | if get_option('phal').enabled() and get_option('p9').enabled() |
| 67 | error('phal and p9 cannot be selected at the same time') |
| 68 | endif |
| 69 | |
| 70 | build_p9 = not get_option('p9').disabled() |
| 71 | build_openfsi = not get_option('openfsi').disabled() |
| 72 | build_phal = get_option('phal').enabled() |
| 73 | |
| 74 | if get_option('phal').enabled() and not get_option('p9').disabled() |
| 75 | build_p9 = false |
| 76 | endif |
| 77 | |
| 78 | summary('building p9', build_p9) |
| 79 | summary('building openfsi', build_openfsi) |
| 80 | summary('building phal', build_phal) |
| 81 | |
| 82 | if build_p9 |
| 83 | extra_sources += [ |
| 84 | 'procedures/p9/cleanup_pcie.cpp', |
| 85 | 'procedures/p9/set_sync_fsi_clock_mode.cpp', |
| 86 | 'procedures/p9/start_host.cpp', |
| 87 | 'procedures/p9/start_host_mpreboot.cpp', |
Jayanth Othayoth | db8d46c | 2021-10-09 02:19:57 -0500 | [diff] [blame] | 88 | 'procedures/p9/enter_mpreboot.cpp', |
Jayanth Othayoth | ee10ead | 2021-12-05 22:54:06 -0600 | [diff] [blame^] | 89 | 'procedures/p9/thread_stopall.cpp', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 90 | ] |
| 91 | endif |
| 92 | if build_openfsi |
| 93 | extra_sources += [ |
| 94 | 'procedures/openfsi/scan.cpp', |
| 95 | ] |
| 96 | endif |
| 97 | if build_phal |
| 98 | extra_sources += [ |
| 99 | 'procedures/phal/start_host.cpp', |
| 100 | 'procedures/phal/set_SPI_mux.cpp', |
Chirag Sharma | a257693 | 2020-12-05 23:17:41 -0600 | [diff] [blame] | 101 | 'procedures/phal/proc_pre_poweroff.cpp', |
Jayanth Othayoth | cf2da1b | 2021-07-29 03:15:20 -0500 | [diff] [blame] | 102 | 'procedures/phal/check_host_running.cpp', |
| 103 | 'procedures/phal/import_devtree.cpp', |
Jayanth Othayoth | db8d46c | 2021-10-09 02:19:57 -0500 | [diff] [blame] | 104 | 'procedures/phal/enter_mpreboot.cpp', |
Jayanth Othayoth | 94fc70c | 2021-11-25 08:18:03 -0600 | [diff] [blame] | 105 | 'procedures/phal/reinit_devtree.cpp', |
Jayanth Othayoth | 5f2eaf1 | 2021-11-30 11:08:51 -0600 | [diff] [blame] | 106 | 'procedures/phal/thread_stopall.cpp', |
Jayanth Othayoth | 25e39c8 | 2021-07-12 01:00:17 -0500 | [diff] [blame] | 107 | 'extensions/phal/common_utils.cpp', |
Jayanth Othayoth | c3d6b87 | 2021-07-28 05:07:25 -0500 | [diff] [blame] | 108 | 'extensions/phal/pdbg_utils.cpp', |
Jayanth Othayoth | 6552de0 | 2021-07-12 00:55:57 -0500 | [diff] [blame] | 109 | 'extensions/phal/create_pel.cpp', |
| 110 | 'extensions/phal/phal_error.cpp', |
Jayanth Othayoth | 21a889f | 2021-10-07 06:53:40 -0500 | [diff] [blame] | 111 | 'extensions/phal/dump_utils.cpp', |
Jayanth Othayoth | 4f7b9bd | 2021-11-25 08:11:12 -0600 | [diff] [blame] | 112 | 'temporary_file.cpp', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 113 | ] |
| 114 | extra_dependencies += [ |
| 115 | dependency('libdt-api'), |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 116 | cxx.find_library('ekb'), |
| 117 | cxx.find_library('ipl'), |
Jayanth Othayoth | 4079f09 | 2021-09-20 07:36:54 -0500 | [diff] [blame] | 118 | cxx.find_library('phal'), |
Jayanth Othayoth | 94fc70c | 2021-11-25 08:18:03 -0600 | [diff] [blame] | 119 | cxx.find_library('dtree'), |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 120 | ] |
| 121 | extra_unit_files = [ |
Andrew Geissler | 1dc0829 | 2021-06-22 17:14:54 -0500 | [diff] [blame] | 122 | 'service_files/set-spi-mux.service', |
| 123 | 'service_files/phal-reinit-devtree.service', |
| 124 | 'service_files/proc-pre-poweroff@.service', |
Andrew Geissler | 8e73da0 | 2021-06-23 15:43:21 -0500 | [diff] [blame] | 125 | 'service_files/op-reset-host-check@.service', |
Andrew Geissler | 3292c06 | 2021-06-23 21:11:10 -0500 | [diff] [blame] | 126 | 'service_files/op-reset-host-clear.service', |
Jayanth Othayoth | a089bd2 | 2021-07-30 01:32:31 -0500 | [diff] [blame] | 127 | 'service_files/phal-import-devtree@.service', |
Jayanth Othayoth | 07e9a6a | 2021-07-30 03:52:13 -0500 | [diff] [blame] | 128 | 'service_files/phal-export-devtree@.service', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 129 | ] |
Brad Bishop | a5b4b1b | 2020-11-08 12:14:03 -0500 | [diff] [blame] | 130 | unit_subs.set('ENABLE_PHAL_TRUE', '') |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 131 | endif |
| 132 | |
| 133 | executable( |
| 134 | 'openpower-proc-control', |
| 135 | [ |
| 136 | 'cfam_access.cpp', |
| 137 | 'ext_interface.cpp', |
| 138 | 'filedescriptor.cpp', |
| 139 | 'proc_control.cpp', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 140 | 'targeting.cpp', |
| 141 | 'procedures/common/cfam_overrides.cpp', |
| 142 | 'procedures/common/cfam_reset.cpp', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 143 | 'procedures/common/collect_sbe_hb_data.cpp', |
Jayanth Othayoth | c483181 | 2021-06-08 01:33:40 -0500 | [diff] [blame] | 144 | 'util.cpp', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 145 | ] + extra_sources, |
| 146 | dependencies: [ |
| 147 | dependency('libgpiodcxx'), |
| 148 | cxx.find_library('pdbg'), |
| 149 | dependency('phosphor-dbus-interfaces'), |
| 150 | dependency('phosphor-logging'), |
| 151 | dependency('sdbusplus'), |
| 152 | dependency('threads'), |
Jayanth Othayoth | c483181 | 2021-06-08 01:33:40 -0500 | [diff] [blame] | 153 | dependency('fmt'), |
Brad Bishop | ce08fb9 | 2020-11-08 09:50:48 -0500 | [diff] [blame] | 154 | ] + extra_dependencies, |
| 155 | install: true |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 156 | ) |
| 157 | |
| 158 | executable( |
| 159 | 'openpower-proc-nmi', |
| 160 | [ |
| 161 | 'nmi_main.cpp', |
| 162 | 'nmi_interface.cpp', |
| 163 | ], |
| 164 | dependencies: [ |
| 165 | cxx.find_library('pdbg'), |
| 166 | dependency('phosphor-dbus-interfaces'), |
| 167 | dependency('phosphor-logging'), |
| 168 | dependency('sdbusplus'), |
Brad Bishop | ce08fb9 | 2020-11-08 09:50:48 -0500 | [diff] [blame] | 169 | ], |
| 170 | install: true |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 171 | ) |
| 172 | |
Jayanth Othayoth | 13c57ad | 2021-07-16 06:02:21 -0500 | [diff] [blame] | 173 | if build_phal |
| 174 | executable( |
| 175 | 'phal-export-devtree', |
| 176 | [ |
| 177 | 'extensions/phal/devtree_export.cpp', |
| 178 | 'extensions/phal/fw_update_watch.cpp', |
Jayanth Othayoth | 3840547 | 2021-07-26 06:16:44 -0500 | [diff] [blame] | 179 | 'extensions/phal/pdbg_utils.cpp', |
| 180 | 'extensions/phal/create_pel.cpp', |
| 181 | 'util.cpp', |
Jayanth Othayoth | 13c57ad | 2021-07-16 06:02:21 -0500 | [diff] [blame] | 182 | ], |
| 183 | dependencies: [ |
| 184 | dependency('phosphor-logging'), |
| 185 | dependency('sdbusplus'), |
| 186 | dependency('sdeventplus'), |
| 187 | dependency('fmt'), |
Jayanth Othayoth | 3840547 | 2021-07-26 06:16:44 -0500 | [diff] [blame] | 188 | dependency('phosphor-dbus-interfaces'), |
| 189 | cxx.find_library('pdbg'), |
Jayanth Othayoth | 13c57ad | 2021-07-16 06:02:21 -0500 | [diff] [blame] | 190 | ], |
| 191 | install: true |
| 192 | ) |
| 193 | endif |
| 194 | |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 195 | unit_files = [ |
Andrew Geissler | 1dc0829 | 2021-06-22 17:14:54 -0500 | [diff] [blame] | 196 | 'service_files/pcie-poweroff@.service', |
| 197 | 'service_files/xyz.openbmc_project.Control.Host.NMI.service', |
| 198 | 'service_files/op-stop-instructions@.service', |
| 199 | 'service_files/op-cfam-reset.service', |
| 200 | 'service_files/op-continue-mpreboot@.service', |
| 201 | 'service_files/op-enter-mpreboot@.service', |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 202 | ] + extra_unit_files |
| 203 | |
| 204 | systemd_system_unit_dir = dependency('systemd').get_pkgconfig_variable( |
| 205 | 'systemdsystemunitdir', |
| 206 | define_variable: ['prefix', get_option('prefix')]) |
| 207 | foreach u : unit_files |
| 208 | configure_file( |
| 209 | configuration: unit_subs, |
| 210 | input: u + '.in', |
| 211 | install: true, |
| 212 | install_dir: systemd_system_unit_dir, |
Andrew Geissler | 1dc0829 | 2021-06-22 17:14:54 -0500 | [diff] [blame] | 213 | output: '@BASENAME@' |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 214 | ) |
| 215 | endforeach |
| 216 | |
| 217 | if not get_option('tests').disabled() |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 218 | test( |
| 219 | 'utest', |
| 220 | executable( |
| 221 | 'utest', |
| 222 | 'test/utest.cpp', |
| 223 | 'targeting.cpp', |
| 224 | 'filedescriptor.cpp', |
| 225 | dependencies: [ |
Brad Bishop | 5d482d9 | 2020-11-08 09:45:18 -0500 | [diff] [blame] | 226 | dependency('gtest', main: true), |
Brad Bishop | 919e408 | 2020-10-27 18:55:19 -0400 | [diff] [blame] | 227 | dependency('phosphor-logging'), |
| 228 | ], |
| 229 | implicit_include_directories: false, |
| 230 | include_directories: '.', |
| 231 | ) |
| 232 | ) |
| 233 | endif |