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