# Copyright (c) 2016-2020, Intel Corporation # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are met: # # * Redistributions of source code must retain the above copyright notice, # this list of conditions and the following disclaimer. # * Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # * Neither the name of Intel Corporation nor the names of its contributors # may be used to endorse or promote products derived from this software # without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE # DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR # SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. %global githubname intel-cmt-cat %global githubver 23.11 %if %{defined githubsubver} %global githubfull %{githubname}-%{githubver}.%{githubsubver} %else %global githubfull %{githubname}-%{githubver} %endif # disable producing debuginfo for this package %global debug_package %{nil} Summary: Provides command line interface to CMT, MBM, CAT, CDP and MBA technologies Name: %{githubname} Release: 2%{?dist} Version: %{githubver} License: BSD-3-Clause ExclusiveArch: x86_64 i686 i586 %if %{defined githubsubver} Source: https://github.com/intel/%{githubname}/archive/%{githubname}-%{githubver}.%{githubsubver}.tar.gz %else Source: https://github.com/intel/%{githubname}/archive/%{githubname}-%{githubver}.tar.gz %endif Patch0001: 0001-allow-debian-flags-to-be-added.patch Patch0002: 0002-Revert-lib-update-detection-of-non-architectural-L3C.patch URL: https://github.com/intel/%{githubname} BuildRequires: gcc, make %description This software package provides basic support for Cache Monitoring Technology (CMT), Memory Bandwidth Monitoring (MBM), Cache Allocation Technology (CAT), Memory Bandwidth Allocation (MBA), and Code Data Prioratization (CDP). CMT, MBM and CAT are configured using Model Specific Registers (MSRs) to measure last level cache occupancy, set up the class of service masks and manage the association of the cores/logical threads to a class of service. The software executes in user space, and access to the MSRs is obtained through a standard Linux* interface. The virtual file system provides an interface to read and write the MSR registers but it requires root privileges. %package -n intel-cmt-cat-devel Summary: Library and sample code to use CMT, MBM, CAT, CDP and MBA technologies License: BSD Requires: intel-cmt-cat == %{version} ExclusiveArch: x86_64 i686 i586 %description -n intel-cmt-cat-devel This software package provides basic support for Cache Monitoring Technology (CMT), Memory Bandwidth Monitoring (MBM), Cache Allocation Technology (CAT), Memory Bandwidth Allocation (MBA), and Code Data Prioratization (CDP). The package includes library, header file and sample code. For additional information please refer to: https://github.com/intel/%{githubname} %prep %autosetup -p1 -n %{githubfull} %ldconfig_scriptlets %build # RHEL 9's baseline is HSW/HSX, which has neither AVX-512 nor CLWB make %{?_smp_mflags} HAS_AVX512=0 HAS_CLWB=0 %install # Not doing make install as it strips the symbols. # Using files from the build directory. # pqos-* and rdtest are in %{_sbin} in Fedora now, but they are in %{_bin} # in RHEL 9 originally, so, preserving it install -d %{buildroot}/%{_bindir} install -s %{_builddir}/%{githubfull}/pqos/pqos %{buildroot}/%{_bindir} install %{_builddir}/%{githubfull}/pqos/pqos-os %{buildroot}/%{_bindir} install %{_builddir}/%{githubfull}/pqos/pqos-msr %{buildroot}/%{_bindir} sed -i "1s/.*/\#!\/usr\/bin\/bash/" %{buildroot}/%{_bindir}/pqos-* install -d %{buildroot}/%{_mandir}/man8 install -m 0644 %{_builddir}/%{githubfull}/pqos/pqos.8 %{buildroot}/%{_mandir}/man8 ln -sf pqos.8 %{buildroot}/%{_mandir}/man8/pqos-os.8 ln -sf pqos.8 %{buildroot}/%{_mandir}/man8/pqos-msr.8 install -d %{buildroot}/%{_bindir} install -s %{_builddir}/%{githubfull}/rdtset/rdtset %{buildroot}/%{_bindir} install -d %{buildroot}/%{_mandir}/man8 install -m 0644 %{_builddir}/%{githubfull}/rdtset/rdtset.8 %{buildroot}/%{_mandir}/man8 # membw is istalled in %{_bindir} in Fedora, but the man page # is in the section 8 install -d %{buildroot}/%{_bindir} install -s %{_builddir}/%{githubfull}/tools/membw/membw %{buildroot}/%{_bindir} install -d %{buildroot}/%{_mandir}/man8 install -m 0644 %{_builddir}/%{githubfull}/tools/membw/membw.8 %{buildroot}/%{_mandir}/man8 install -d %{buildroot}/%{_licensedir}/%{name} install -m 0644 %{_builddir}/%{githubfull}/LICENSE %{buildroot}/%{_licensedir}/%{name} # Install the library install -d %{buildroot}/%{_libdir} install -s %{_builddir}/%{githubfull}/lib/libpqos.so.* %{buildroot}/%{_libdir} cp -a %{_builddir}/%{githubfull}/lib/libpqos.so %{buildroot}/%{_libdir} cp -a %{_builddir}/%{githubfull}/lib/libpqos.so.5 %{buildroot}/%{_libdir} # Install the header file install -d %{buildroot}/%{_includedir} install -m 0644 %{_builddir}/%{githubfull}/lib/pqos.h %{buildroot}/%{_includedir} # Install license and sample code install -d %{buildroot}/%{_usrsrc}/%{githubfull} install -m 0644 %{_builddir}/%{githubfull}/LICENSE %{buildroot}/%{_usrsrc}/%{githubfull} install -d %{buildroot}/%{_usrsrc}/%{githubfull}/c install -d %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/Makefile %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/README %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/reset_app.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/allocation_app_l2cat.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/allocation_app_l3cat.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/allocation_app_mba.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -m 0644 %{_builddir}/%{githubfull}/examples/c/CAT_MBA/association_app.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/CAT_MBA install -d %{buildroot}/%{_usrsrc}/%{githubfull}/c/CMT_MBM install -m 0644 %{_builddir}/%{githubfull}/examples/c/CMT_MBM/Makefile %{buildroot}/%{_usrsrc}/%{githubfull}/c/CMT_MBM install -m 0644 %{_builddir}/%{githubfull}/examples/c/CMT_MBM/README %{buildroot}/%{_usrsrc}/%{githubfull}/c/CMT_MBM install -m 0644 %{_builddir}/%{githubfull}/examples/c/CMT_MBM/monitor_app.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/CMT_MBM install -d %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/Makefile %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/README %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/dlock.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/dlock.h %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/pseudo_lock.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/tsc.c %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK install -m 0644 %{_builddir}/%{githubfull}/examples/c/PSEUDO_LOCK/tsc.h %{buildroot}/%{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK %files %{_bindir}/pqos %{_bindir}/pqos-os %{_bindir}/pqos-msr %{_mandir}/man8/pqos.8.gz %{_mandir}/man8/pqos-os.8.gz %{_mandir}/man8/pqos-msr.8.gz %{_bindir}/rdtset %{_mandir}/man8/rdtset.8.gz %{_bindir}/membw %{_mandir}/man8/membw.8.gz %{_libdir}/libpqos.so.* %{!?_licensedir:%global license %%doc} %license %{_licensedir}/%{name}/LICENSE %doc ChangeLog README.md %files -n intel-cmt-cat-devel %{_libdir}/libpqos.so %{_libdir}/libpqos.so.5 %{_includedir}/pqos.h %{_usrsrc}/%{githubfull}/c/CAT_MBA/Makefile %{_usrsrc}/%{githubfull}/c/CAT_MBA/README %{_usrsrc}/%{githubfull}/c/CAT_MBA/reset_app.c %{_usrsrc}/%{githubfull}/c/CAT_MBA/association_app.c %{_usrsrc}/%{githubfull}/c/CAT_MBA/allocation_app_l2cat.c %{_usrsrc}/%{githubfull}/c/CAT_MBA/allocation_app_l3cat.c %{_usrsrc}/%{githubfull}/c/CAT_MBA/allocation_app_mba.c %{_usrsrc}/%{githubfull}/c/CMT_MBM/Makefile %{_usrsrc}/%{githubfull}/c/CMT_MBM/README %{_usrsrc}/%{githubfull}/c/CMT_MBM/monitor_app.c %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/Makefile %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/README %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/dlock.c %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/dlock.h %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/pseudo_lock.c %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/tsc.c %{_usrsrc}/%{githubfull}/c/PSEUDO_LOCK/tsc.h %doc %{_usrsrc}/%{githubfull}/LICENSE %changelog * Fri Mar 01 2024 Eugene Syromiatnikov - 23.11-2 - Revert commit "lib: update detection of non-architectural L3CAT" that removed L3CAT detection support on Tiger Lake and Erkhart Lake CPUs (RHEL-22729) * Mon Feb 12 2024 Eugene Syromiatnikov - 23.11-1 - Rebase to 23.11 (RHEL-22729, RHEL-25781) * Mon Aug 09 2021 Mohan Boddu - 4.1.0-3 - Rebuilt for IMA sigs, glibc 2.34, aarch64 flags Related: rhbz#1991688 * Wed Jun 09 2021 Martin Cermak - 4.1.0-2 - CI gating related NVR bump and rebuild * Sun May 02 2021 Jiri Olsa - 4.1.0-1 - RHEL9 release 4.1.0, copied from fedora