blob: 8af1f98ae740c0c3ebc213f4ee6ccc3dd22acaec [file] [log] [blame]
Brad Bishop919e4082020-10-27 18:55:19 -04001project(
2 'openpower-proc-control',
3 'cpp',
4 default_options: [
5 'warning_level=3',
6 'werror=true',
Patrick Williams9e178b72021-10-06 15:33:36 -05007 'cpp_std=c++20',
Brad Bishopf38b35e2020-11-08 10:42:34 -05008 'buildtype=debugoptimized',
9 'b_ndebug=if-release',
Brad Bishop919e4082020-10-27 18:55:19 -040010 ],
11 license: 'Apache-2.0',
12 version: '1.0',
Patrick Williams9e178b72021-10-06 15:33:36 -050013 meson_version: '>=0.57.0',
Brad Bishop919e4082020-10-27 18:55:19 -040014)
15add_project_arguments('-Wno-psabi', language: 'cpp')
16
Patrick Williams9e178b72021-10-06 15:33:36 -050017if get_option('cpp_std') != 'c++20'
18 error('This project requires c++20')
Brad Bishopf38b35e2020-11-08 10:42:34 -050019endif
20
21if(get_option('buildtype') == 'minsize')
22 add_project_arguments('-DNDEBUG', language : 'cpp')
23endif
24
Brad Bishop919e4082020-10-27 18:55:19 -040025cxx = meson.get_compiler('cpp')
26
27extra_sources = []
28extra_dependencies = []
29extra_unit_files = []
30
Jayanth Othayoth38405472021-07-26 06:16:44 -050031# Configuration header file(config.h) generation
32conf_data = configuration_data()
33
34conf_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
38conf_data.set_quoted('DEVTREE_EXP_FILE', get_option('DEVTREE_EXP_FILE'),
39 description : 'Path to the devtree export copy file'
40 )
41
Jayanth Othayoth94fc70c2021-11-25 08:18:03 -060042conf_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 Rao90166c12022-01-07 02:22:53 -060046conf_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 Othayoth94fc70c2021-11-25 08:18:03 -060048 )
Jayanth Othayoth94fc70c2021-11-25 08:18:03 -060049conf_data.set_quoted('CEC_INFODB_PATH', get_option('CEC_INFODB_PATH'),
50 description : 'Path to the devtree attributes based database path'
51 )
52
53conf_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 Othayoth38405472021-07-26 06:16:44 -050057configure_file(configuration : conf_data,
58 output : 'config.h'
59 )
60
Brad Bishop919e4082020-10-27 18:55:19 -040061unit_subs = configuration_data()
Brad Bishopa5b4b1b2020-11-08 12:14:03 -050062unit_subs.set('bindir', join_paths(get_option('prefix'), get_option('bindir')))
63unit_subs.set('ENABLE_PHAL_TRUE', '#')
Brad Bishop919e4082020-10-27 18:55:19 -040064
65if get_option('phal').enabled() and get_option('p9').enabled()
66 error('phal and p9 cannot be selected at the same time')
67endif
68
69build_p9 = not get_option('p9').disabled()
70build_openfsi = not get_option('openfsi').disabled()
71build_phal = get_option('phal').enabled()
72
73if get_option('phal').enabled() and not get_option('p9').disabled()
74 build_p9 = false
75endif
76
77summary('building p9', build_p9)
78summary('building openfsi', build_openfsi)
79summary('building phal', build_phal)
80
81if build_p9
82 extra_sources += [
83 'procedures/p9/cleanup_pcie.cpp',
84 'procedures/p9/set_sync_fsi_clock_mode.cpp',
85 'procedures/p9/start_host.cpp',
86 'procedures/p9/start_host_mpreboot.cpp',
Jayanth Othayothdb8d46c2021-10-09 02:19:57 -050087 'procedures/p9/enter_mpreboot.cpp',
Jayanth Othayothee10ead2021-12-05 22:54:06 -060088 'procedures/p9/thread_stopall.cpp',
Brad Bishop919e4082020-10-27 18:55:19 -040089 ]
90endif
91if build_openfsi
92 extra_sources += [
93 'procedures/openfsi/scan.cpp',
94 ]
95endif
96if build_phal
97 extra_sources += [
98 'procedures/phal/start_host.cpp',
99 'procedures/phal/set_SPI_mux.cpp',
Chirag Sharmaa2576932020-12-05 23:17:41 -0600100 'procedures/phal/proc_pre_poweroff.cpp',
Jayanth Othayothcf2da1b2021-07-29 03:15:20 -0500101 'procedures/phal/check_host_running.cpp',
102 'procedures/phal/import_devtree.cpp',
Jayanth Othayothdb8d46c2021-10-09 02:19:57 -0500103 'procedures/phal/enter_mpreboot.cpp',
Jayanth Othayoth94fc70c2021-11-25 08:18:03 -0600104 'procedures/phal/reinit_devtree.cpp',
Jayanth Othayoth5f2eaf12021-11-30 11:08:51 -0600105 'procedures/phal/thread_stopall.cpp',
Jayanth Othayoth25e39c82021-07-12 01:00:17 -0500106 'extensions/phal/common_utils.cpp',
Jayanth Othayothc3d6b872021-07-28 05:07:25 -0500107 'extensions/phal/pdbg_utils.cpp',
Jayanth Othayoth6552de02021-07-12 00:55:57 -0500108 'extensions/phal/create_pel.cpp',
109 'extensions/phal/phal_error.cpp',
Jayanth Othayoth21a889f2021-10-07 06:53:40 -0500110 'extensions/phal/dump_utils.cpp',
Jayanth Othayoth4f7b9bd2021-11-25 08:11:12 -0600111 'temporary_file.cpp',
Brad Bishop919e4082020-10-27 18:55:19 -0400112 ]
113 extra_dependencies += [
114 dependency('libdt-api'),
Brad Bishop919e4082020-10-27 18:55:19 -0400115 cxx.find_library('ekb'),
116 cxx.find_library('ipl'),
Jayanth Othayoth4079f092021-09-20 07:36:54 -0500117 cxx.find_library('phal'),
Jayanth Othayoth94fc70c2021-11-25 08:18:03 -0600118 cxx.find_library('dtree'),
Brad Bishop919e4082020-10-27 18:55:19 -0400119 ]
120 extra_unit_files = [
Andrew Geissler1dc08292021-06-22 17:14:54 -0500121 'service_files/set-spi-mux.service',
122 'service_files/phal-reinit-devtree.service',
123 'service_files/proc-pre-poweroff@.service',
Andrew Geissler8e73da02021-06-23 15:43:21 -0500124 'service_files/op-reset-host-check@.service',
Andrew Geissler3292c062021-06-23 21:11:10 -0500125 'service_files/op-reset-host-clear.service',
Jayanth Othayotha089bd22021-07-30 01:32:31 -0500126 'service_files/phal-import-devtree@.service',
Jayanth Othayoth07e9a6a2021-07-30 03:52:13 -0500127 'service_files/phal-export-devtree@.service',
Brad Bishop919e4082020-10-27 18:55:19 -0400128 ]
Brad Bishopa5b4b1b2020-11-08 12:14:03 -0500129 unit_subs.set('ENABLE_PHAL_TRUE', '')
Brad Bishop919e4082020-10-27 18:55:19 -0400130endif
131
132executable(
133 'openpower-proc-control',
134 [
135 'cfam_access.cpp',
136 'ext_interface.cpp',
137 'filedescriptor.cpp',
138 'proc_control.cpp',
Brad Bishop919e4082020-10-27 18:55:19 -0400139 'targeting.cpp',
140 'procedures/common/cfam_overrides.cpp',
141 'procedures/common/cfam_reset.cpp',
Brad Bishop919e4082020-10-27 18:55:19 -0400142 'procedures/common/collect_sbe_hb_data.cpp',
Jayanth Othayothc4831812021-06-08 01:33:40 -0500143 'util.cpp',
Brad Bishop919e4082020-10-27 18:55:19 -0400144 ] + extra_sources,
145 dependencies: [
146 dependency('libgpiodcxx'),
147 cxx.find_library('pdbg'),
148 dependency('phosphor-dbus-interfaces'),
149 dependency('phosphor-logging'),
150 dependency('sdbusplus'),
151 dependency('threads'),
Jayanth Othayothc4831812021-06-08 01:33:40 -0500152 dependency('fmt'),
Brad Bishopce08fb92020-11-08 09:50:48 -0500153 ] + extra_dependencies,
154 install: true
Brad Bishop919e4082020-10-27 18:55:19 -0400155)
156
157executable(
158 'openpower-proc-nmi',
159 [
160 'nmi_main.cpp',
161 'nmi_interface.cpp',
162 ],
163 dependencies: [
164 cxx.find_library('pdbg'),
165 dependency('phosphor-dbus-interfaces'),
166 dependency('phosphor-logging'),
167 dependency('sdbusplus'),
Brad Bishopce08fb92020-11-08 09:50:48 -0500168 ],
169 install: true
Brad Bishop919e4082020-10-27 18:55:19 -0400170)
171
Jayanth Othayoth13c57ad2021-07-16 06:02:21 -0500172if build_phal
173 executable(
174 'phal-export-devtree',
175 [
176 'extensions/phal/devtree_export.cpp',
177 'extensions/phal/fw_update_watch.cpp',
Jayanth Othayoth38405472021-07-26 06:16:44 -0500178 'extensions/phal/pdbg_utils.cpp',
179 'extensions/phal/create_pel.cpp',
180 'util.cpp',
Jayanth Othayoth13c57ad2021-07-16 06:02:21 -0500181 ],
182 dependencies: [
183 dependency('phosphor-logging'),
184 dependency('sdbusplus'),
185 dependency('sdeventplus'),
186 dependency('fmt'),
Jayanth Othayoth38405472021-07-26 06:16:44 -0500187 dependency('phosphor-dbus-interfaces'),
188 cxx.find_library('pdbg'),
Jayanth Othayoth13c57ad2021-07-16 06:02:21 -0500189 ],
190 install: true
191 )
192endif
193
Brad Bishop919e4082020-10-27 18:55:19 -0400194unit_files = [
Andrew Geissler1dc08292021-06-22 17:14:54 -0500195 'service_files/pcie-poweroff@.service',
196 'service_files/xyz.openbmc_project.Control.Host.NMI.service',
197 'service_files/op-stop-instructions@.service',
198 'service_files/op-cfam-reset.service',
199 'service_files/op-continue-mpreboot@.service',
200 'service_files/op-enter-mpreboot@.service',
Brad Bishop919e4082020-10-27 18:55:19 -0400201] + extra_unit_files
202
203systemd_system_unit_dir = dependency('systemd').get_pkgconfig_variable(
204 'systemdsystemunitdir',
205 define_variable: ['prefix', get_option('prefix')])
206foreach u : unit_files
207 configure_file(
208 configuration: unit_subs,
209 input: u + '.in',
210 install: true,
211 install_dir: systemd_system_unit_dir,
Andrew Geissler1dc08292021-06-22 17:14:54 -0500212 output: '@BASENAME@'
Brad Bishop919e4082020-10-27 18:55:19 -0400213 )
214endforeach
215
216if not get_option('tests').disabled()
Brad Bishop919e4082020-10-27 18:55:19 -0400217 test(
218 'utest',
219 executable(
220 'utest',
221 'test/utest.cpp',
222 'targeting.cpp',
223 'filedescriptor.cpp',
224 dependencies: [
Brad Bishop5d482d92020-11-08 09:45:18 -0500225 dependency('gtest', main: true),
Brad Bishop919e4082020-10-27 18:55:19 -0400226 dependency('phosphor-logging'),
227 ],
228 implicit_include_directories: false,
229 include_directories: '.',
230 )
231 )
232endif