# Invocation command line:
# /mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/bin/harness/runcpu --configfile amd_speed_aocc500_znver5_A1.cfg --tune all --reportable --iterations 2 --define DL-BIOS-NPS=4 --define DL-VERS=6.1a --output_format html,pdf,txt --nopower --runmode speed --tune base:peak --size test:train:refspeed intspeed
# output_root was not used for this run
############################################################################
################################################################################
# AMD AOCC 500 SPEC CPU 2017 V1.1.9 Speed Configuration File for 64-bit Linux
#
#      File name                : amd_speed_aocc500_znver5_A1.cfg
#      Creation Date            : September 11, 2024
#      CPU 2017 Version         : 1.1.9
#      Supported benchmarks     : All Speed benchmarks (intspeed, fpspeed)
#      Compiler name/version    : AOCC 5.0.0
#      Operating system version : Ubuntu 22.04
#      Supported OS's           : SLE 15 SP6, Ubuntu 22.04/24.04
#      Hardware                 : AMD Turin (AMD64)
#      FP Base Pointer Size     : 64-bit
#      FP Peak Pointer Size     : 64-bit
#      INT Base Pointer Size    : 64-bit
#      INT Peak Pointer Size    : 32/64-bit
#      Auto Parallelization     : No
#
# Note: DO NOT EDIT THIS FILE, the only edits required to properly run these
# binaries are made in the ini Python file.  Please consult Readme.amd_speed_aocc500_znver5_A1.txt
# for a few uncommon exceptions which require edits to this file.
#
# Description:
#
# This binary package automates away many of the complexities necessary to set
# up and run SPEC CPU 2017 under optimized conditions on AMD znver5-based
# server platforms within Linux (AMD64).
#
# The binary package was built specifically for AMD znver5 microprocessors and
# is not intended to run on other products.
#
# Please install the binary package by following the instructions in
# "Readme.amd_speed_aocc500_znver5_A1.txt" under the "How To Use the Binaries" section.
#
# The binary package is designed to work without alteration on one socket AMD
# znver5-based servers with 96 cores, SMT enabled and 768 (64x12) GB of DDR5
# memory distributed evenly among all 12 channels using 64 GiB DIMMs.
#
# To run the binary package on other znver5 configurations, please review
# "Readme.amd_speed_aocc500_znver5_A1.txt". In general, znver5 CPUs
# should be autodetected with no action required by the user.
#
# In most cases, it should be unnecessary to edit "amd_speed_aocc500_znver5_A1.cfg" or any
# other file besides "ini_amd_speed_aocc500_znver5_A1.py" where reporting fields
# and run conditions are set.
#
# The run script automatically sets the optimal number of speed copies and binds
# them appropriately.
#
# The run script and accompanying binary package are designed to work on Ubuntu
# 22.04, RHEL 8.6/9, and SLE 15 SP4.
#
# Important! If you write your own run script, please set the stack size to
# "unlimited" when executing this binary package.  Failure to do so may cause
# some benchmarks to overflow the stack.  For example, to set stack size within
# the bash shell, include the following line somewhere at the top of your run
# script before the runcpu invocation:
#
#      ulimit -s unlimited
#
# Modification of this config file should only be necessary if you intend to
# rebuild the binaries.  General instructions for rebuilding the binaries are
# found in-line below.
#
################################################################################
# Modifiable macros:
################################################################################
# "allow_build"" switch:
# Change the following line to true if you intend to REBUILD the binaries (AMD
# does not support this). Valid values are "true" or "false" (no quotes).
%define allow_build false
# Only change these macros if you are rebuilding the binary package:
%define compiler_name aocc500
%define binary_package_name amd_speed_%{compiler_name}_znver5_A
%define binary_package_ext %{binary_package_name}
%define binary_package_revision 1
%define build_path /home/work/cpu2017/v119/aocc5/1316
%define flags_file_name  %{compiler_name}-flags-A1.xml
# Do NOT change build_lib_dir after the build or it will trigger a
# rebuild of the xalanc. It should also remain literal:
%define build_lib_dir amd_speed_aocc500_znver5_A_lib
# To enable the platform file, be sure to uncomment the flagsurl02 header line
# below in the Header settings.
%define platform_file_name INVALID_platform_%{binary_package_name}.xml
################################################################################
# You should never have to change binary_package_full_name:
%define binary_package_full_name %{binary_package_name}%{binary_package_revision}

################################################################################
# Include file name
################################################################################
# The include file contains fields that are commonly changed. This file is auto-
# generated based upon INI file settings and should not need user modification
# for runs.

%define inc_file_name %{binary_package_full_name}.inc
%define flags_inc_file_name %{binary_package_full_name}_flags.inc
%define port_flags_inc_file_name %{binary_package_full_name}_flags_portability.inc
%define workaround_flags_inc_file_name %{binary_package_full_name}_flags_workaround.inc

# Binary label extension:
# Only modify the binary label extension if you plan to rebuild the binaries.
# If you plan to recompile these CPU 2017 binaries, please choose a new extension
# name below to avoid confusion with the current binary set on your system
# under test, and to avoid confusion for SPEC submission reviewers.  You will
# also need to set "allow_build" to true above. Finally, you must modify the
# Paths section below to point to your library locations if the paths are not
# already set up in your build environment.
# Note that AMD calls an external script to set up the compiler and library
# paths before initiating the build.

%define ext %{binary_package_ext}

################################################################################
# Paths and Environment Variables
# ** MODIFY AS NEEDED (modification should not be necessary for runs) **
################################################################################
# Allow environment variables to be set before runs:
preenv                   = 1

# retain:true is necessary to avoid gcc out-of-memory exceptions on certain SUTs:
# oversize_threshold is required to support jemalloc 5.2.x+
preENV_MALLOC_CONF = retain:true
preENV_LIBOMP_NUM_HIDDEN_HELPER_THREADS = 0

# OpenMP environment variables:
preENV_OMP_SCHEDULE      = static
preENV_OMP_DYNAMIC       = false
preENV_OMP_STACKSIZE     = 128M

# Define the name of the directory that holds AMD library files:
%define lib_dir %{binary_package_name}_lib


# Set the shared object library path for runs and builds:
preENV_LD_LIBRARY_PATH   = $[top]/%{lib_dir}/lib:$[top]/%{lib_dir}/lib32:%{ENV_LD_LIBRARY_PATH}
# Define 32-bit library build paths:
# Do NOT use $[top] with the 32-bit libraries because doing so will cause an
# options checksum error triggering a xalanc recompile attempt on SUTs having
# different file paths.
# Do NOT change build_lib_dir after the build or it will also trigger a
# rebuild of the xalanc:
AMDALLOC_LIB32_PATH      = %{build_path}/%{build_lib_dir}/lib32
%if '%{allow_build}' eq 'false'
  # The include file is only needed for runs, but not for builds.
#  include: %{inc_file_name}
#  ----- Begin inclusion of 'amd_speed_aocc500_znver5_A1.inc'
############################################################################
################################################################################
################################################################################
# File name: amd_speed_aocc500_znver5_A1.inc
# File generation code date: August 29, 2024
# File generation date/time: February 08, 2025 / 01:48:37
#
# This file is automatically generated during a SPEC CPU2017 run.
#
# To modify inc file generation, please consult the readme file or the run
# script.
################################################################################
################################################################################

################################################################################
################################################################################
# The following macros are generated for use in the cfg file.
################################################################################
################################################################################

%define logical_core_count 256
%define physical_core_count 256

################################################################################
################################################################################
# The following inc blocks set the speed thread counts and affinity settings.
#
# intspeed benchmarks: 600.perlbench_s,602.gcc_s,605.mcf_s,620.omnetpp_s,
#   623.xalancbmk_s,625.x264_s,631.deepsjeng_s,641.leela_s,648.exchange2_s,
#   657.xz_s
# fpspeed benchmarks: 603.bwaves_s,607.cactuBSSN_s,619.lbm_s,621.wrf_s,
#   627.cam4_s,628.pop2_s,638.imagick_s,644.nab_s,649.fotonik3d_s,
#   654.roms_s
#
# Selected thread counts from '9755' section of CPU info
################################################################################
# default preENV thread settings:
default:
preENV_OMP_THREAD_LIMIT  = 256
preENV_GOMP_CPU_AFFINITY = 0-255
################################################################################
################################################################################
# intspeed base thread counts:
intspeed=base:
threads                  = 256
ENV_GOMP_CPU_AFFINITY    = 0-255
bind0                    = numactl --physcpubind=0-255
submit = echo "$command" > run.sh ; $BIND bash run.sh
################################################################################
################################################################################
# fpspeed base thread counts:
fpspeed=base:
threads                  = 256
ENV_GOMP_CPU_AFFINITY    = 0-255
bind0                    = numactl --physcpubind=0-255
submit = echo "$command" > run.sh ; $BIND bash run.sh
################################################################################
################################################################################
# peak thread counts: 1
600.perlbench_s,602.gcc_s,605.mcf_s,620.omnetpp_s,623.xalancbmk_s,625.x264_s,631.deepsjeng_s,641.leela_s,648.exchange2_s=peak:
threads                  = 1
ENV_GOMP_CPU_AFFINITY    = 0
bind0                    = numactl --physcpubind=0
submit = echo "$command" > run.sh ; $BIND bash run.sh
################################################################################
################################################################################
# peak thread counts: 256
603.bwaves_s,607.cactuBSSN_s,619.lbm_s,621.wrf_s,628.pop2_s,638.imagick_s,644.nab_s,649.fotonik3d_s=peak:
threads                  = 256
ENV_GOMP_CPU_AFFINITY    = 0-255
bind0                    = numactl --physcpubind=0-255
submit = echo "$command" > run.sh ; $BIND bash run.sh
################################################################################
################################################################################
# peak thread counts: 256
627.cam4_s,654.roms_s,657.xz_s=peak:
threads                  = 256
ENV_GOMP_CPU_AFFINITY    = 0-255
bind0                    = numactl --physcpubind=0-255
submit = echo "$command" > run.sh ; $BIND bash run.sh
################################################################################

################################################################################
################################################################################
# Switch back to default:
default:
################################################################################


################################################################################
################################################################################
# The remainder of this file defines CPU2017 report parameters.
################################################################################
################################################################################
################################################################################
# SPEC CPU 2017 report header
################################################################################
license_num              =9999 # (Your SPEC license number)
tester                   =unknown tester
test_sponsor             =unknown sponsor
hw_vendor                =unknown vendor
#--------- If you install new compilers, edit this section --------------------
sw_compiler              =C/C++/Fortran: Version 5.0.0 of AOCC
################################################################################

################################################################################
# Hardware, firmware and software information
################################################################################
hw_avail                 =Oct-2024
sw_avail                 =Oct-2024
hw_cpu_name              =AMD EPYC 9755
hw_cpu_nominal_mhz       =2700
hw_cpu_max_mhz           =4100
hw_ncores                =256
hw_nthreadspercore       =1
hw_ncpuorder             =1,2 chips

hw_other                 =None                  # Other perf-relevant hw, or "None"
fw_bios                  =Version 0.0.0 released Jun-2023
sw_base_ptrsize          =64-bit
hw_pcache                =32 KB I + 48 KB D on chip per core
hw_scache                =1 MB I+D on chip per core
hw_tcache000             =512 MB I+D on chip per chip, 32 MB shared / 8
hw_tcache001 = cores
hw_ocache                =None
sw_other                 =None

################################################################################
# Notes
################################################################################



# Enter notes_000 through notes_100 here.
notes_000                =Binaries were compiled on a system with 2x AMD EPYC 9D64 CPU + 500GiB Memory using Ubuntu 22.04


notes_005                =
notes_010                =NA: The test sponsor attests, as of date of publication, that CVE-2017-5754 (Meltdown)
notes_015                =is mitigated in the system as tested and documented.
notes_020                =Yes: The test sponsor attests, as of date of publication, that CVE-2017-5753 (Spectre variant 1)
notes_025                =is mitigated in the system as tested and documented.
notes_030                =Yes: The test sponsor attests, as of date of publication, that CVE-2017-5715 (Spectre variant 2)
notes_035                =is mitigated in the system as tested and documented.
notes_040                =


notes_submit_000         ='numactl' was used to bind copies to the cores.
notes_submit_005         =See the configuration file for details.
notes_submit_010         =


notes_os_000             ='ulimit -s unlimited' was used to set environment stack size limit
notes_os_005             ='ulimit -l 2097152' was used to set environment locked pages in memory limit
notes_os_010             =
notes_os_015             =runcpu command invoked through numactl i.e.:
notes_os_020             =numactl --interleave=all runcpu <etc>
notes_os_025             =
notes_os_030             =To limit dirty cache to 8% of memory, 'sysctl -w vm.dirty_ratio=8' run as root.
notes_os_035             =To limit swap usage to minimum necessary, 'sysctl -w vm.swappiness=1' run as root.
notes_os_040             =To free node-local memory and avoid remote memory usage,
notes_os_045             ='sysctl -w vm.zone_reclaim_mode=1' run as root.
notes_os_050             =To clear filesystem caches, 'sync; sysctl -w vm.drop_caches=3' run as root.
notes_os_055             =To disable address space layout randomization (ASLR) to reduce run-to-run
notes_os_060             =variability, 'sysctl -w kernel.randomize_va_space=0' run as root.
notes_os_065             =


notes_comp_000           =The AMD64 AOCC Compiler Suite is available at
notes_comp_005           =http://developer.amd.com/amd-aocc/
notes_comp_010           =
# notes_jemalloc_000       =jemalloc: configured and built with GCC v4.8.2 in RHEL 7.4 (No options specified)
# notes_jemalloc_005       =jemalloc 5.1.0 is available here:
# notes_jemalloc_010       =https://github.com/jemalloc/jemalloc/releases/download/5.1.0/jemalloc-5.1.0.tar.bz2
# notes_jemalloc_015       =
# sw_other000              =jemalloc: jemalloc memory allocator library v5.1.0

################################################################################
# The following note fields describe platorm settings.
################################################################################

# example: (edit and uncomment as necessary)
# notes_plat_000 =BIOS settings:
# notes_plat_002 = TDP: 400
# notes_plat_004 = Determinism Slider set to Power
# notes_plat_006 = PPT: 400
# notes_plat_010 = NPS: 4
# notes_plat_011 = Workload Profile = CPU Intensive
# notes_plat_012 = TSME = Disabled
# notes_plat_014 = SEV Control = Disabled
# notes_plat_015 = Fan Speed: Maximum


################################################################################
# The following are custom fields:
################################################################################

# Use custom_fields to enter lines that are not listed here. For example:
# notes_plat_100         = Energy Bias set to Max Performance
# new_field              = Ambient temperature set to 10C


################################################################################
# The following fields must be set here for only Int benchmarks.
################################################################################
intspeed:

sw_peak_ptrsize          =64-bit

notes_os_thp_000         =To enable Transparent Hugepages (THP) only on request for base runs,
notes_os_thp_005         ='echo madvise > /sys/kernel/mm/transparent_hugepage/enabled' run as root.
notes_os_thp_010         =To enable THP for all allocations for peak runs,
notes_os_thp_015         ='echo always > /sys/kernel/mm/transparent_hugepage/enabled' and
notes_os_thp_020         ='echo always > /sys/kernel/mm/transparent_hugepage/defrag' run as root.
notes_os_thp_025         =


################################################################################
# The following fields must be set here for FP benchmarks.
################################################################################
fpspeed:

sw_peak_ptrsize          =64-bit

notes_os_thp_000         =To enable Transparent Hugepages (THP) for all allocations,
notes_os_thp_001         ='echo always > /sys/kernel/mm/transparent_hugepage/enabled' and
notes_os_thp_002         ='echo always > /sys/kernel/mm/transparent_hugepage/defrag' run as root.
notes_os_thp_003         =


################################################################################
# The following fields must be set here or they will be overwritten by sysinfo.
################################################################################

intspeed,fpspeed:
hw_disk                  =unknown

hw_nchips                =2
prepared_by              =prepared by unknown
sw_file                  =unknown file
sw_state                 =Run level 3 (multi-user)

################################################################################
# End of inc file
################################################################################
# Switch back to the default block after the include file:

default:

# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/amd_speed_aocc500_znver5_A1.inc'
  # Switch back to default block after the include file:
default:
  fail_build             = yes # FIX THIS SO THAT CHECKSUMS WILL BE ENFORCED!
%elif '%{allow_build}' eq 'true'
  # If you intend to rebuild, be sure to set the library paths either in the
  # build script or here:
  preENV_LIBRARY_PATH   = $[top]/%{build_lib_dir}/lib:$[top]/%{build_lib_dir}/lib32:%{ENV_LIBRARY_PATH}
% define build_ncpus 64    # controls number of simultaneous compiles
  fail_build             = 0
  makeflags              = --jobs=%{build_ncpus} --load-average=%{build_ncpus}
%else
% error The value of "allow_build" is %{allow_build}, but it can only be "true" or "false". This error was generated
%endif


################################################################################
# Enable automated data collection per benchmark
################################################################################
# Data collection is not enabled for reportable runs.

# teeout is necessary to get data collection stdout into the logs. Best
# practices for the individual data collection items would be to have
# them store important output in separate files.  Filenames could be
# constructed from $SPEC (environment), $lognum (result number from runcpu),
# and benchmark name/number.
#teeout = yes

# Run runcpu with '-v 35' (or greater) to log lists of variables which can
# be used in substitutions as below.
# For CPU2006, change $label to $ext
%define data-collection-parameters benchname='$name' benchnum='$num' benchmark='$benchmark' iteration=$iter size='$size' tune='$tune' label='$label' log='$log' lognum='$lognum' from_runcpu='$from_runcpu'
%define data-collection-start $[top]/data-collection/data-collection start %{data-collection-parameters}
%define data-collection-stop  $[top]/data-collection/data-collection stop %{data-collection-parameters}
monitor_specrun_wrapper = %{data-collection-start} ; $command ; %{data-collection-stop}


################################################################################
# Header settings
################################################################################
backup_config            = 0 # set to 0 if you do not want backup files
bench_post_setup         = sync
# command_add_redirect: If set, the generated ${command} will include
# redirection operators (stdout, stderr), which are passed along to the shell
# that executes the command. If this variable is not set, specinvoke does the
# redirection.
command_add_redirect     = yes
env_vars                 = yes
flagsurl000              = http://www.spec.org/cpu2017/flags/aocc500-flags.xml
#flagsurl02              = $[top]/%{platform_file_name}
# label: User defined extension string that tags your binaries & directories:
label                    = %{ext}
line_width               = 1020
log_line_width           = 1020
mean_anyway              = yes
output_format            = all
reportable               = yes
size                     = test,train,ref
#teeout                   = yes
#teerunout                = yes
tune                     = base,peak
use_submit_for_speed     = yes


################################################################################
# Include the flags file:
################################################################################

#include: %{flags_inc_file_name}
#  ----- Begin inclusion of 'amd_speed_aocc500_znver5_A1_flags.inc'
############################################################################
################################################################################
# AMD AOCC 5.0.0 SPEC CPU2017 V1.1.9 Speed Configuration Flags for AMD64 Linux
################################################################################
# Compilers
################################################################################

default:

CC                       = clang   -m64
CXX                      = clang++ -m64 -std=c++14
FC                       = flang   -m64
CLD                      = clang   -m64
CXXLD                    = clang++ -m64 -std=c++14
FLD                      = flang   -m64
CC_VERSION_OPTION        = --version
CXX_VERSION_OPTION       = --version
FC_VERSION_OPTION        = --version

################################################################################
# Default libraries and variables
################################################################################

default:

# Libraries:
EXTRA_LIBS               = -fopenmp=libomp \
                           -lomp \
                           -lamdalloc \
                           -lamdlibm \
                           -lm

MATHLIBOPT               = #clearing this variable or else SPEC will set it to -lm

VECMATHLIB               = -fveclib=AMDLIBM

# Variables:
OPT_ROOT                 = -march=znver5 \
                           $(VECMATHLIB) \
                           -ffast-math \
                           -fopenmp

OPT_ROOT_BASE            = -O3 \
                           $(OPT_ROOT)

OPT_ROOT_PEAK            = -Ofast \
                           $(OPT_ROOT) \
                           -flto

THP_ALWAYS               = echo always > /sys/kernel/mm/transparent_hugepage/enabled; echo always > /sys/kernel/mm/transparent_hugepage/defrag
THP_NEVER                = echo never > /sys/kernel/mm/transparent_hugepage/enabled; echo never > /sys/kernel/mm/transparent_hugepage/defrag
THP_MADVISE              = echo madvise > /sys/kernel/mm/transparent_hugepage/enabled; echo madvise > /sys/kernel/mm/transparent_hugepage/defrag
DEFAULT_SUBMIT           = $BIND $command


################################################################################
# Portability and workaround include files
################################################################################

# Portability flags include file:
#include: %{port_flags_inc_file_name}
#  ----- Begin inclusion of 'amd_speed_aocc500_znver5_A1_flags_portability.inc'
############################################################################
################################################################################
# AMD AOCC 5.0.0 SPEC CPU2017 V1.1.9 Speed Portability Flags for AMD64 Linux
################################################################################

default:
# data model applies to all benchmarks
EXTRA_PORTABILITY         = -DSPEC_LP64

# *** Benchmark-specific portability ***
# Anything other than the data model is only allowed where a need is proven.
# (ordered by last 2 digits of benchmark number)

600.perlbench_s:  #lang='C'
PORTABILITY              = -DSPEC_LINUX_X64

621.wrf_s:  #lang='F,C'
CPORTABILITY             = -DSPEC_CASE_FLAG
FPORTABILITY             = -Mbyteswapio

623.xalancbmk_s:  #lang='CXX'
PORTABILITY              = -DSPEC_LINUX

627.cam4_s:  #lang='F,C'
PORTABILITY              = -DSPEC_CASE_FLAG

628.pop2_s:  #lang='F,C'
CPORTABILITY             = -DSPEC_CASE_FLAG
FPORTABILITY             = -Mbyteswapio

################################################################################
# End Portability Flags
################################################################################
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/amd_speed_aocc500_znver5_A1_flags_portability.inc'

# Workaround flags include file:
#include: %{workaround_flags_inc_file_name}
#  ----- Begin inclusion of 'amd_speed_aocc500_znver5_A1_flags_workaround.inc'
############################################################################
################################################################################
# AMD AOCC 5.0.0 SPEC CPU2017 V1.1.9 Speed Workaround Flags for AMD64 Linux
################################################################################
# The workarounds in this section would not qualify under the SPEC CPU
# PORTABILITY rule.
#   - In peak, they can be set as needed for individual benchmarks.
#   - In base, individual settings are not allowed; set for whole suite.
# Use EXTRA_CFLAGS, EXTRA_CXXFLAGS, and EXTRA_FFLAGS for them.
#
# See:
#     https://www.spec.org/cpu2017/Docs/runrules.html#portability
#     https://www.spec.org/cpu2017/Docs/runrules.html#BaseFlags

#######################
# Default workarounds #
#######################

default:
# Allow unused compile/link arguments without triggering warnings during build:
EXTRA_CFLAGS             = -Wno-unused-command-line-argument
EXTRA_CXXFLAGS           = -Wno-unused-command-line-argument
EXTRA_FFLAGS             = -Wno-unused-command-line-argument
LDOPTIONS                = -Wno-unused-command-line-argument

####################
# Base workarounds #
####################
#
# *** NONE ***
#

##############################
# Integer workarounds - base #
##############################
#
# *** NONE ***
#

#########################
# FP workarounds - base #
#########################
#
# *** NONE ***
#

####################
# Peak workarounds #
####################
#
# *** NONE ***
#

##############################
# Integer workarounds - peak #
##############################
#
# *** NONE ***
#

#####################################
# Floating Point workarounds - peak #
#####################################
#
# *** NONE ***
#
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/amd_speed_aocc500_znver5_A1_flags_workaround.inc'

################################################################################
# Tuning Flags
################################################################################

#####################
# Base tuning flags #
#####################

default=base:

COPTIMIZE                = $(OPT_ROOT_BASE) \
                           -DSPEC_OPENMP \
                           -flto \
                           -fremap-arrays \
                           -fstrip-mining \
                           -fstruct-layout=7 \
                           -mllvm -inline-threshold=1000 \
                           -mllvm -reduce-array-computations=3 \
                           -mllvm -unroll-threshold=50 \
                           -Wno-return-type \
                           -zopt

CXXOPTIMIZE              = $(OPT_ROOT_BASE) \
                           -DSPEC_OPENMP \
                           -flto \
                           -mllvm -loop-unswitch-threshold=200000 \
                           -mllvm -reduce-array-computations=3 \
                           -mllvm -unroll-threshold=100 \
                           -zopt

FOPTIMIZE                = $(OPT_ROOT_BASE) \
                           -DSPEC_OPENMP \
                           -flto \
                           -funroll-loops \
                           -mllvm -lsr-in-nested-loop \
                           -mllvm -reduce-array-computations=3 \
                           -Mrecursive \
                           -zopt

LDCXXFLAGS               = -Wl,-mllvm -Wl,-x86-use-vzeroupper=false

LDFLAGS                  = -Wl,-mllvm -Wl,-align-all-nofallthru-blocks=6 \
                           -Wl,-mllvm -Wl,-reduce-array-computations=3

LDFFLAGS                 = -Wl,-mllvm -Wl,-enable-X86-prefetching

#other libraries
# Put OpenMP and math libraries here:
# -lm needed at the end for some transcendental functions:
EXTRA_LIBS               = -fopenmp=libomp \
                           -lomp \
                           -lamdlibm \
                           -lamdalloc \
                           -lflang \
                           -lm

EXTRA_FLIBS              =

# Don't put the AMD and mvec math libraries in MATHLIBOPT because it will trigger a reporting issue
# because GCC won't use them. Forcefeed all benchmarks the math libraries in EXTRA_LIBS and clear
# out MATHLIBOPT.
MATHLIBOPT               =


#########################
# intspeed tuning flags #
#########################

intspeed:

FOPTIMIZE                = $(OPT_ROOT_BASE) \
                           -flto \
                           -mllvm -optimize-strided-mem-cost

EXTRA_FFLAGS             = -mllvm -unroll-aggressive \
                           -mllvm -unroll-threshold=150

EXTRA_CXXFLAGS           = -fvirtual-function-elimination \
                           -fvisibility=hidden

LDFLAGS                  = -Wl,-mllvm -Wl,-align-all-nofallthru-blocks=6 \
                           -Wl,-mllvm -Wl,-reduce-array-computations=3

LDCFLAGS                 = -Wl,-allow-multiple-definition \
                           -Wl,-mllvm -Wl,-extra-inliner

LDCXXFLAGS               =

LDFFLAGS                 = -Wl,-mllvm -Wl,-enable-iv-split \
                           -Wl,-mllvm -Wl,-inline-recursion=4 \
                           -Wl,-mllvm -Wl,-lsr-in-nested-loop

##############################
# intspeed base tuning flags #
##############################

intspeed=base:

EXTRA_LIBS               = -fopenmp=libomp \
                           -lomp \
                           -lamdlibm \
                           -lflang \
                           -lm

EXTRA_CLIBS              = -lamdalloc
EXTRA_CXXLIBS            = -lamdalloc-ext
EXTRA_FLIBS              = -lamdalloc

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

##############################
# intspeed peak tuning flags #
##############################

intspeed=peak:

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}


#############################
# fpspeed base tuning flags #
#############################

fpspeed=base:
EXTRA_CFLAGS             = -mrecip=none \
                           -Wno-unused-command-line-argument

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

#############################
# fpspeed peak tuning flags #
#############################

fpspeed=peak:

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

#####################
# Peak tuning flags #
#####################

default=peak:

COPTIMIZE                = $(OPT_ROOT_PEAK) \
                           -DSPEC_OPENMP \
                           -fremap-arrays \
                           -fstrip-mining \
                           -fstruct-layout=9 \
                           -mllvm -inline-threshold=1000 \
                           -mllvm -reduce-array-computations=3 \
                           -mllvm -unroll-threshold=50 \
                           -Wno-return-type \
                           -zopt

CXXOPTIMIZE              = $(OPT_ROOT_PEAK) \
                           -DSPEC_OPENMP \
                           -mllvm -reduce-array-computations=3 \
                           -mllvm -unroll-threshold=100 \
                           -zopt

FOPTIMIZE                = $(OPT_ROOT_PEAK) \
                           -DSPEC_OPENMP \
                           -mllvm -reduce-array-computations=3 \
                           -Mrecursive \
                           -zopt

LDFLAGS                  = -Wl,-mllvm -Wl,-align-all-nofallthru-blocks=6 \
                           -Wl,-mllvm -Wl,-reduce-array-computations=3

LDFFLAGS                 = -Wl,-mllvm -Wl,-enable-X86-prefetching

LDCXXFLAGS               = -Wl,-mllvm -Wl,-x86-use-vzeroupper=false

EXTRA_LIBS               = -fopenmp=libomp \
                           -lomp \
                           -lamdlibm \
                           -lamdalloc \
                           -lflang \
                           -lm

feedback                 = 0
PASS1_CFLAGS             = -fprofile-instr-generate
PASS2_CFLAGS             = -fprofile-instr-use
PASS1_FFLAGS             = -fprofile-generate
PASS2_FFLAGS             = -fprofile-use
PASS1_CXXFLAGS           = -fprofile-instr-generate
PASS2_CXXFLAGS           = -fprofile-instr-use
PASS1_LDFLAGS            = -fprofile-instr-generate
PASS2_LDFLAGS            = -fprofile-instr-use
fdo_run1                 = $command ; llvm-profdata merge --output=default.profdata *.profraw


# Benchmark specific peak tuning flags:

600.perlbench_s=peak: #lang='C'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

602.gcc_s=peak: #lang='C'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

603.bwaves_s=peak: #lang='F'
FOPTIMIZE                = -Ofast \
                           $(OPT_ROOT) \
                           -DSPEC_OPENMP \
                           -fscalar-transform \
                           -fvector-transform \
                           -mllvm -reduce-array-computations=3 \
                           -Mrecursive
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

605.mcf_s=peak: #lang='C'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}
LDCFLAGS                 = -Wl,-mllvm -Wl,-extra-inliner

607.cactuBSSN_s=peak: #lang='CXX,C,F'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

619.lbm_s=peak: #lang='C'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

620.omnetpp_s=peak: #lang='CXX'
EXTRA_LIBS               = -fopenmp=libomp \
                           -lomp \
                           -lamdlibm \
                           -lamdalloc-ext \
                           -lflang -lm
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

621.wrf_s=peak: #lang='F,C'
FOPTIMIZE                = $(OPT_ROOT) \
                           -Ofast \
                           -DSPEC_OPENMP \
                           -funroll-loops \
                           -mllvm -lsr-in-nested-loop \
                           -mllvm -reduce-array-computations=3 \
                           -Mrecursive \
                           -zopt
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

623.xalancbmk_s=peak: #lang='CXX'
EXTRA_CXXFLAGS           = -fvirtual-function-elimination \
                           -fvisibility=hidden \
                           -mllvm -do-block-reorder=advanced

LDFLAGS                  = -Wl,-mllvm -Wl,-align-all-nofallthru-blocks=6 \
                           -Wl,-mllvm -Wl,-reduce-array-computations=3 \
                           -Wl,-mllvm -Wl,-do-block-reorder=advanced

EXTRA_LIBS               = -fopenmp=libomp \
                           -lomp \
                           -lamdlibm \
                           -lamdalloc-ext \
                           -lflang \
                           -lm
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

625.x264_s=peak: #lang='C'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

627.cam4_s=peak: #lang='F,C'
EXTRA_CFLAGS             = -mrecip=none \
                           -Wno-unused-command-line-argument

LDFLAGS                  = -Wl,-mllvm -Wl,-align-all-nofallthru-blocks=6 \
                           -Wl,-mllvm -Wl,-reduce-array-computations=3

submit                   = ${THP_NEVER}; ${DEFAULT_SUBMIT}

628.pop2_s=peak: #lang='F,C'
FOPTIMIZE                = $(OPT_ROOT) \
                           -Ofast \
                           -DSPEC_OPENMP \
                           -fscalar-transform \
                           -fvector-transform \
                           -mllvm -reduce-array-computations=3 \
                           -Mrecursive
submit                   = ${THP_MADVISE}; ${DEFAULT_SUBMIT}

631.deepsjeng_s=peak: #lang='CXX'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

638.imagick_s=peak: #lang='C'
LDFLAGS                  = -Wl,-mllvm -Wl,-align-all-nofallthru-blocks=6 \
                           -Wl,-mllvm -Wl,-reduce-array-computations=3

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

641.leela_s=peak: #lang='CXX'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

644.nab_s=peak: #lang='C'
EXTRA_CFLAGS             = -mrecip=none \
                           -Wno-unused-command-line-argument

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

648.exchange2_s=peak: #lang='F'
submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

649.fotonik3d_s=peak: #lang='F'

submit                   = ${THP_ALWAYS}; ${DEFAULT_SUBMIT}

654.roms_s=peak: #lang='F'
FOPTIMIZE                = -Ofast \
                           $(OPT_ROOT) \
                           -DSPEC_OPENMP \
                           -fscalar-transform \
                           -fvector-transform \
                           -mllvm -reduce-array-computations=3 \
                           -Mrecursive

submit                   = ${THP_NEVER}; ${DEFAULT_SUBMIT}
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/amd_speed_aocc500_znver5_A1_flags.inc'

%ifdef %{DL-VERS}

# Dell include
#include: Dell.inc
#  ----- Begin inclusion of 'Dell.inc'
############################################################################
#----------------------------
# Dell
#---------------------------

#-------------------------------------------
# **** DO NOT EDIT BELOW HERE!!!
#-------------------------------------------

# Allow stand-alone run
fprate,fpspeed,intrate,intspeed:
hw_vendor     = Dell Inc.
tester        = Dell Inc.
test_sponsor  = Dell Inc.
prepared_by   = Dell 6.1a

# License : Old number 55
license_num   = 6573

#include: Dell-flags.inc
#  ----- Begin inclusion of 'Dell-flags.inc'
############################################################################
#-------------------------------------------------------
# Dell platform flags (Auto)
#-------------------------------------------------------
default:
flagsurl001=http://www.spec.org/cpu2017/flags/Dell-Platform-Flags-PowerEdge-AMD-EPYC-v1.4.xml
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/Dell-flags.inc'
#include: Dell-BIOS.inc
#  ----- Begin inclusion of 'Dell-BIOS.inc'
############################################################################
fprate,fpspeed,intrate,intspeed:
notes_plat_form_000 =
notes_plat_form_005 = BIOS Settings:
notes_plat_form_010 =                    Logical Processor : Disabled
notes_plat_form_015 =            Virtualization Technology : Disabled
notes_plat_form_020 =                NUMA Nodes Per Socket : 4
notes_plat_form_025 =
notes_plat_form_030 =                       System Profile : Custom
notes_plat_form_035 =                             C-States : Disabled
notes_plat_form_040 =                  Memory Patrol Scrub : Disabled
notes_plat_form_045 =    PCI ASPM L1 Link Power Management : Disabled
notes_plat_form_050 =      Periodic Directory Rinse Tuning : Blended
notes_plat_form_055 =                  Determinism Control : Manual
notes_plat_form_060 =                   Determinism Slider : Power Determinism
notes_plat_form_065 =                       Optimizer Mode : Enabled
notes_plat_form_070 =  Algorithm Performance Boost Disable : Enabled
notes_plat_form_075 =                  Adaptive Allocation : Enabled
notes_plat_form_080 =                   Dram Refresh Delay : Performance
notes_plat_form_085 =                  DIMM Self Healing -
notes_plat_form_090 =        on Uncorrectable Memory Error : Disabled
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/Dell-BIOS.inc'
#include: Dell-cleanup.inc
#  ----- Begin inclusion of 'Dell-cleanup.inc'
############################################################################
#-------------------------------------------------------
# Dell
#
# AMD
#-------------------------------------------------------

# cleanup - sysinfo/AMD scripts
fprate,fpspeed,intspeed,intrate:
#sw_os000 = %undef%
#sw_os001 = %undef%
sw_os002 = %undef%

#hw_memory000 = %undef%
hw_memory001 = %undef%
hw_memory002 = %undef%

#hw_model000 = %undef%
#hw_model001 = %undef%
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/Dell-cleanup.inc'
#
#include: Dell-Autogen.inc
#  ----- Begin inclusion of 'Dell-Autogen.inc'
############################################################################
fprate,fpspeed,intrate,intspeed:
hw_model000          = PowerEdge XE7745 (AMD EPYC 9755 128-Core
hw_model001 = Processor)
hw_cpu_name          = AMD EPYC 9755
hw_cpu_max_mhz       = 4100
hw_ncpuorder         = 1,2 chips
hw_ncores            = 256
hw_nthreadspercore   = 1
fw_bios              = Version 1.0.3 released Jan-2025
sw_state             = Run level 5 (graphical multi-user)
sw_file              = tmpfs
hw_disk              = 130 GB on tmpfs
notes_tmpfs_000      =
notes_tmpfs_005      = Benchmark run from a 130 GB ramdisk created with the cmd: "mount -t tmpfs -o size=130G tmpfs /mnt/ramdisk"
sw_os000             = Ubuntu 24.04 LTS
sw_os001             = 6.8.0-52-generic
hw_cpu_nominal_mhz   = 2700
hw_memory000         = 1536 GB (24 x 64 GB 2Rx4 PC5-6400B-R, running at
hw_memory001 = 6000)
sw_avail             = Jan-2025
hw_avail             = Feb-2025
hw_other             = CPU Cooling: Air
power_management000  = BIOS and OS set to prefer performance at the cost
power_management001 = of additional power usage.
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/Dell-Autogen.inc'
# ---- End inclusion of '/mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/config/Dell.inc'

%endif


# The following settings were obtained by running the sysinfo_program
# 'specperl $[top]/bin/sysinfo' (sysinfo:SHA:2eb381fc1a58eb8122e4a1b875c1e38b3489dac84088192aa0ec6d157b084d06)
default:
notes_plat_sysinfo_000 =
notes_plat_sysinfo_005 = Sysinfo program /mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1/bin/sysinfo
notes_plat_sysinfo_010 = Rev: r6732 of 2022-11-07 fe91c89b7ed5c36ae2c92cc097bec197
notes_plat_sysinfo_015 = running on 1234567-XE7745 Sat Feb  8 01:48:41 2025
notes_plat_sysinfo_020 =
notes_plat_sysinfo_025 = SUT (System Under Test) info as seen by some common utilities.
notes_plat_sysinfo_030 =
notes_plat_sysinfo_035 = ------------------------------------------------------------
notes_plat_sysinfo_040 = Table of contents
notes_plat_sysinfo_045 = ------------------------------------------------------------
notes_plat_sysinfo_050 =  1. uname -a
notes_plat_sysinfo_055 =  2. w
notes_plat_sysinfo_060 =  3. Username
notes_plat_sysinfo_065 =  4. ulimit -a
notes_plat_sysinfo_070 =  5. sysinfo process ancestry
notes_plat_sysinfo_075 =  6. /proc/cpuinfo
notes_plat_sysinfo_080 =  7. lscpu
notes_plat_sysinfo_085 =  8. numactl --hardware
notes_plat_sysinfo_090 =  9. /proc/meminfo
notes_plat_sysinfo_095 = 10. who -r
notes_plat_sysinfo_100 = 11. Systemd service manager version: systemd 255 (255.4-1ubuntu8)
notes_plat_sysinfo_105 = 12. Failed units, from systemctl list-units --state=failed
notes_plat_sysinfo_110 = 13. Services, from systemctl list-unit-files
notes_plat_sysinfo_115 = 14. Linux kernel boot-time arguments, from /proc/cmdline
notes_plat_sysinfo_120 = 15. cpupower frequency-info
notes_plat_sysinfo_125 = 16. tuned-adm active
notes_plat_sysinfo_130 = 17. sysctl
notes_plat_sysinfo_135 = 18. /sys/kernel/mm/transparent_hugepage
notes_plat_sysinfo_140 = 19. /sys/kernel/mm/transparent_hugepage/khugepaged
notes_plat_sysinfo_145 = 20. OS release
notes_plat_sysinfo_150 = 21. Disk information
notes_plat_sysinfo_155 = 22. /sys/devices/virtual/dmi/id
notes_plat_sysinfo_160 = 23. dmidecode
notes_plat_sysinfo_165 = 24. BIOS
notes_plat_sysinfo_170 = ------------------------------------------------------------
notes_plat_sysinfo_175 =
notes_plat_sysinfo_180 = ------------------------------------------------------------
notes_plat_sysinfo_185 = 1. uname -a
notes_plat_sysinfo_190 =   Linux 1234567-XE7745 6.8.0-52-generic #53-Ubuntu SMP PREEMPT_DYNAMIC Sat Jan 11 00:06:25 UTC 2025 x86_64
notes_plat_sysinfo_195 =   x86_64 x86_64 GNU/Linux
notes_plat_sysinfo_200 =
notes_plat_sysinfo_205 = ------------------------------------------------------------
notes_plat_sysinfo_210 = 2. w
notes_plat_sysinfo_215 =    01:48:41 up 12 min,  1 user,  load average: 0.05, 0.25, 0.43
notes_plat_sysinfo_220 =   USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
notes_plat_sysinfo_225 =   root     tty1     -                01:38   39.00s  1.18s  0.36s /bin/bash ./amd_speed_aocc500_znver5_A1.sh
notes_plat_sysinfo_230 =
notes_plat_sysinfo_235 = ------------------------------------------------------------
notes_plat_sysinfo_240 = 3. Username
notes_plat_sysinfo_245 =   From environment variable $USER:  root
notes_plat_sysinfo_250 =
notes_plat_sysinfo_255 = ------------------------------------------------------------
notes_plat_sysinfo_260 = 4. ulimit -a
notes_plat_sysinfo_265 =   time(seconds)        unlimited
notes_plat_sysinfo_270 =   file(blocks)         unlimited
notes_plat_sysinfo_275 =   data(kbytes)         unlimited
notes_plat_sysinfo_280 =   stack(kbytes)        unlimited
notes_plat_sysinfo_285 =   coredump(blocks)     0
notes_plat_sysinfo_290 =   memory(kbytes)       unlimited
notes_plat_sysinfo_295 =   locked memory(kbytes) 2097152
notes_plat_sysinfo_300 =   process              6188989
notes_plat_sysinfo_305 =   nofiles              1024
notes_plat_sysinfo_310 =   vmemory(kbytes)      unlimited
notes_plat_sysinfo_315 =   locks                unlimited
notes_plat_sysinfo_320 =   rtprio               0
notes_plat_sysinfo_325 =
notes_plat_sysinfo_330 = ------------------------------------------------------------
notes_plat_sysinfo_335 = 5. sysinfo process ancestry
notes_plat_sysinfo_340 =  /sbin/init
notes_plat_sysinfo_345 =  /bin/login -f --
notes_plat_sysinfo_350 =  -bash
notes_plat_sysinfo_355 =  /bin/bash /home/DellFiles/bin/DELL_speed.sh
notes_plat_sysinfo_360 =  /bin/bash /home/DellFiles/bin/dell-run-main.sh speed
notes_plat_sysinfo_365 =  /bin/bash /home/DellFiles/bin/dell-run-main.sh speed
notes_plat_sysinfo_370 =  /bin/bash /home/DellFiles/bin/AMD/dell-run-speccpu.sh speed --define DL-VERS=6.1a --output_format
notes_plat_sysinfo_375 =    html,pdf,txt
notes_plat_sysinfo_380 =  python3 ./run_amd_speed_aocc500_znver5_A1.py
notes_plat_sysinfo_385 =  /bin/bash ./amd_speed_aocc500_znver5_A1.sh
notes_plat_sysinfo_390 =  runcpu --config amd_speed_aocc500_znver5_A1.cfg --tune all --reportable --iterations 2 --define
notes_plat_sysinfo_395 =    DL-BIOS-NPS=4 --define DL-VERS=6.1a --output_format html,pdf,txt intspeed
notes_plat_sysinfo_400 =  runcpu --configfile amd_speed_aocc500_znver5_A1.cfg --tune all --reportable --iterations 2 --define
notes_plat_sysinfo_405 =    DL-BIOS-NPS=4 --define DL-VERS=6.1a --output_format html,pdf,txt --nopower --runmode speed --tune
notes_plat_sysinfo_410 =    base:peak --size test:train:refspeed intspeed --nopreenv --note-preenv --logfile
notes_plat_sysinfo_415 =    $SPEC/tmp/CPU2017.001/templogs/preenv.intspeed.001.0.log --lognum 001.0 --from_runcpu 2
notes_plat_sysinfo_420 =  specperl $SPEC/bin/sysinfo
notes_plat_sysinfo_425 = $SPEC = /mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1
notes_plat_sysinfo_430 =
notes_plat_sysinfo_435 = ------------------------------------------------------------
notes_plat_sysinfo_440 = 6. /proc/cpuinfo
notes_plat_sysinfo_445 =     model name      : AMD EPYC 9755 128-Core Processor
notes_plat_sysinfo_450 =     vendor_id       : AuthenticAMD
notes_plat_sysinfo_455 =     cpu family      : 26
notes_plat_sysinfo_460 =     model           : 2
notes_plat_sysinfo_465 =     stepping        : 1
notes_plat_sysinfo_470 =     microcode       : 0xb00211a
notes_plat_sysinfo_475 =     bugs            : sysret_ss_attrs spectre_v1 spectre_v2 spec_store_bypass
notes_plat_sysinfo_480 =     TLB size        : 192 4K pages
notes_plat_sysinfo_485 =     cpu cores       : 128
notes_plat_sysinfo_490 =     siblings        : 128
notes_plat_sysinfo_495 =     2 physical ids (chips)
notes_plat_sysinfo_500 =     256 processors (hardware threads)
notes_plat_sysinfo_505 =     physical id 0: core ids
notes_plat_sysinfo_510 =     0-7,16-23,32-39,48-55,64-71,80-87,96-103,112-119,128-135,144-151,160-167,176-183,192-199,208-215,224-231,
notes_plat_sysinfo_515 =     240-247
notes_plat_sysinfo_520 =     physical id 1: core ids
notes_plat_sysinfo_525 =     0-7,16-23,32-39,48-55,64-71,80-87,96-103,112-119,128-135,144-151,160-167,176-183,192-199,208-215,224-231,
notes_plat_sysinfo_530 =     240-247
notes_plat_sysinfo_535 =     physical id 0: apicids
notes_plat_sysinfo_540 =     0-7,16-23,32-39,48-55,64-71,80-87,96-103,112-119,128-135,144-151,160-167,176-183,192-199,208-215,224-231,
notes_plat_sysinfo_545 =     240-247
notes_plat_sysinfo_550 =     physical id 1: apicids
notes_plat_sysinfo_555 =     256-263,272-279,288-295,304-311,320-327,336-343,352-359,368-375,384-391,400-407,416-423,432-439,448-455,4
notes_plat_sysinfo_560 =     64-471,480-487,496-503
notes_plat_sysinfo_565 =   Caution: /proc/cpuinfo data regarding chips, cores, and threads is not necessarily reliable, especially for
notes_plat_sysinfo_570 =   virtualized systems.  Use the above data carefully.
notes_plat_sysinfo_575 =
notes_plat_sysinfo_580 = ------------------------------------------------------------
notes_plat_sysinfo_585 = 7. lscpu
notes_plat_sysinfo_590 =
notes_plat_sysinfo_595 = From lscpu from util-linux 2.39.3:
notes_plat_sysinfo_600 =   Architecture:                         x86_64
notes_plat_sysinfo_605 =   CPU op-mode(s):                       32-bit, 64-bit
notes_plat_sysinfo_610 =   Address sizes:                        52 bits physical, 57 bits virtual
notes_plat_sysinfo_615 =   Byte Order:                           Little Endian
notes_plat_sysinfo_620 =   CPU(s):                               256
notes_plat_sysinfo_625 =   On-line CPU(s) list:                  0-255
notes_plat_sysinfo_630 =   Vendor ID:                            AuthenticAMD
notes_plat_sysinfo_635 =   BIOS Vendor ID:                       AMD
notes_plat_sysinfo_640 =   Model name:                           AMD EPYC 9755 128-Core Processor
notes_plat_sysinfo_645 =   BIOS Model name:                      AMD EPYC 9755 128-Core Processor                 CPU @ 2.7GHz
notes_plat_sysinfo_650 =   BIOS CPU family:                      107
notes_plat_sysinfo_655 =   CPU family:                           26
notes_plat_sysinfo_660 =   Model:                                2
notes_plat_sysinfo_665 =   Thread(s) per core:                   1
notes_plat_sysinfo_670 =   Core(s) per socket:                   128
notes_plat_sysinfo_675 =   Socket(s):                            2
notes_plat_sysinfo_680 =   Stepping:                             1
notes_plat_sysinfo_685 =   Frequency boost:                      enabled
notes_plat_sysinfo_690 =   CPU(s) scaling MHz:                   66%
notes_plat_sysinfo_695 =   CPU max MHz:                          4121.1909
notes_plat_sysinfo_700 =   CPU min MHz:                          1500.0000
notes_plat_sysinfo_705 =   BogoMIPS:                             5392.79
notes_plat_sysinfo_710 =   Flags:                                fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat
notes_plat_sysinfo_715 =                                         pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt pdpe1gb
notes_plat_sysinfo_720 =                                         rdtscp lm constant_tsc rep_good amd_lbr_v2 nopl nonstop_tsc cpuid
notes_plat_sysinfo_725 =                                         extd_apicid aperfmperf rapl pni pclmulqdq monitor ssse3 fma cx16 pcid
notes_plat_sysinfo_730 =                                         sse4_1 sse4_2 x2apic movbe popcnt aes xsave avx f16c rdrand lahf_lm
notes_plat_sysinfo_735 =                                         cmp_legacy extapic cr8_legacy abm sse4a misalignsse 3dnowprefetch
notes_plat_sysinfo_740 =                                         osvw ibs skinit wdt tce topoext perfctr_core perfctr_nb bpext
notes_plat_sysinfo_745 =                                         perfctr_llc mwaitx cpb cat_l3 cdp_l3 hw_pstate ssbd mba perfmon_v2
notes_plat_sysinfo_750 =                                         ibrs ibpb stibp ibrs_enhanced vmmcall fsgsbase tsc_adjust bmi1 avx2
notes_plat_sysinfo_755 =                                         smep bmi2 invpcid cqm rdt_a avx512f avx512dq rdseed adx smap
notes_plat_sysinfo_760 =                                         avx512ifma clflushopt clwb avx512cd sha_ni avx512bw avx512vl xsaveopt
notes_plat_sysinfo_765 =                                         xsavec xgetbv1 xsaves cqm_llc cqm_occup_llc cqm_mbm_total
notes_plat_sysinfo_770 =                                         cqm_mbm_local user_shstk avx_vnni avx512_bf16 clzero irperf
notes_plat_sysinfo_775 =                                         xsaveerptr rdpru wbnoinvd amd_ppin cppc arat npt lbrv svm_lock
notes_plat_sysinfo_780 =                                         nrip_save tsc_scale vmcb_clean flushbyasid decodeassists pausefilter
notes_plat_sysinfo_785 =                                         pfthreshold avic v_vmsave_vmload vgif x2avic v_spec_ctrl vnmi
notes_plat_sysinfo_790 =                                         avx512vbmi umip pku ospke avx512_vbmi2 gfni vaes vpclmulqdq
notes_plat_sysinfo_795 =                                         avx512_vnni avx512_bitalg avx512_vpopcntdq la57 rdpid bus_lock_detect
notes_plat_sysinfo_800 =                                         movdiri movdir64b overflow_recov succor smca avx512_vp2intersect
notes_plat_sysinfo_805 =                                         flush_l1d debug_swap
notes_plat_sysinfo_810 =   L1d cache:                            12 MiB (256 instances)
notes_plat_sysinfo_815 =   L1i cache:                            8 MiB (256 instances)
notes_plat_sysinfo_820 =   L2 cache:                             256 MiB (256 instances)
notes_plat_sysinfo_825 =   L3 cache:                             1 GiB (32 instances)
notes_plat_sysinfo_830 =   NUMA node(s):                         8
notes_plat_sysinfo_835 =   NUMA node0 CPU(s):                    0-31
notes_plat_sysinfo_840 =   NUMA node1 CPU(s):                    32-63
notes_plat_sysinfo_845 =   NUMA node2 CPU(s):                    64-95
notes_plat_sysinfo_850 =   NUMA node3 CPU(s):                    96-127
notes_plat_sysinfo_855 =   NUMA node4 CPU(s):                    128-159
notes_plat_sysinfo_860 =   NUMA node5 CPU(s):                    160-191
notes_plat_sysinfo_865 =   NUMA node6 CPU(s):                    192-223
notes_plat_sysinfo_870 =   NUMA node7 CPU(s):                    224-255
notes_plat_sysinfo_875 =   Vulnerability Gather data sampling:   Not affected
notes_plat_sysinfo_880 =   Vulnerability Itlb multihit:          Not affected
notes_plat_sysinfo_885 =   Vulnerability L1tf:                   Not affected
notes_plat_sysinfo_890 =   Vulnerability Mds:                    Not affected
notes_plat_sysinfo_895 =   Vulnerability Meltdown:               Not affected
notes_plat_sysinfo_900 =   Vulnerability Mmio stale data:        Not affected
notes_plat_sysinfo_905 =   Vulnerability Reg file data sampling: Not affected
notes_plat_sysinfo_910 =   Vulnerability Retbleed:               Not affected
notes_plat_sysinfo_915 =   Vulnerability Spec rstack overflow:   Not affected
notes_plat_sysinfo_920 =   Vulnerability Spec store bypass:      Mitigation; Speculative Store Bypass disabled via prctl
notes_plat_sysinfo_925 =   Vulnerability Spectre v1:             Mitigation; usercopy/swapgs barriers and __user pointer sanitization
notes_plat_sysinfo_930 =   Vulnerability Spectre v2:             Mitigation; Enhanced / Automatic IBRS; IBPB conditional; STIBP
notes_plat_sysinfo_935 =                                         disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected
notes_plat_sysinfo_940 =   Vulnerability Srbds:                  Not affected
notes_plat_sysinfo_945 =   Vulnerability Tsx async abort:        Not affected
notes_plat_sysinfo_950 =
notes_plat_sysinfo_955 = From lscpu --cache:
notes_plat_sysinfo_960 =      NAME ONE-SIZE ALL-SIZE WAYS TYPE        LEVEL  SETS PHY-LINE COHERENCY-SIZE
notes_plat_sysinfo_965 =      L1d       48K      12M   12 Data            1    64        1             64
notes_plat_sysinfo_970 =      L1i       32K       8M    8 Instruction     1    64        1             64
notes_plat_sysinfo_975 =      L2         1M     256M   16 Unified         2  1024        1             64
notes_plat_sysinfo_980 =      L3        32M       1G   16 Unified         3 32768        1             64
notes_plat_sysinfo_985 =
notes_plat_sysinfo_990 = ------------------------------------------------------------
notes_plat_sysinfo_995 = 8. numactl --hardware
notes_plat_sysinfo_1000= NOTE: a numactl 'node' might or might not correspond to a physical chip.
notes_plat_sysinfo_1005=   available: 8 nodes (0-7)
notes_plat_sysinfo_1010=   node 0 cpus: 0-31
notes_plat_sysinfo_1015=   node 0 size: 192727 MB
notes_plat_sysinfo_1020=   node 0 free: 188148 MB
notes_plat_sysinfo_1025=   node 1 cpus: 32-63
notes_plat_sysinfo_1030=   node 1 size: 193520 MB
notes_plat_sysinfo_1035=   node 1 free: 192631 MB
notes_plat_sysinfo_1040=   node 2 cpus: 64-95
notes_plat_sysinfo_1045=   node 2 size: 193520 MB
notes_plat_sysinfo_1050=   node 2 free: 193133 MB
notes_plat_sysinfo_1055=   node 3 cpus: 96-127
notes_plat_sysinfo_1060=   node 3 size: 193504 MB
notes_plat_sysinfo_1065=   node 3 free: 193208 MB
notes_plat_sysinfo_1070=   node 4 cpus: 128-159
notes_plat_sysinfo_1075=   node 4 size: 193520 MB
notes_plat_sysinfo_1080=   node 4 free: 193195 MB
notes_plat_sysinfo_1085=   node 5 cpus: 160-191
notes_plat_sysinfo_1090=   node 5 size: 193520 MB
notes_plat_sysinfo_1095=   node 5 free: 193032 MB
notes_plat_sysinfo_1100=   node 6 cpus: 192-223
notes_plat_sysinfo_1105=   node 6 size: 193520 MB
notes_plat_sysinfo_1110=   node 6 free: 193150 MB
notes_plat_sysinfo_1115=   node 7 cpus: 224-255
notes_plat_sysinfo_1120=   node 7 size: 193481 MB
notes_plat_sysinfo_1125=   node 7 free: 193089 MB
notes_plat_sysinfo_1130=   node distances:
notes_plat_sysinfo_1135=   node   0   1   2   3   4   5   6   7
notes_plat_sysinfo_1140=     0:  10  12  12  12  32  32  32  32
notes_plat_sysinfo_1145=     1:  12  10  12  12  32  32  32  32
notes_plat_sysinfo_1150=     2:  12  12  10  12  32  32  32  32
notes_plat_sysinfo_1155=     3:  12  12  12  10  32  32  32  32
notes_plat_sysinfo_1160=     4:  32  32  32  32  10  12  12  12
notes_plat_sysinfo_1165=     5:  32  32  32  32  12  10  12  12
notes_plat_sysinfo_1170=     6:  32  32  32  32  12  12  10  12
notes_plat_sysinfo_1175=     7:  32  32  32  32  12  12  12  10
notes_plat_sysinfo_1180=
notes_plat_sysinfo_1185= ------------------------------------------------------------
notes_plat_sysinfo_1190= 9. /proc/meminfo
notes_plat_sysinfo_1195=    MemTotal:       1584453936 kB
notes_plat_sysinfo_1200=
notes_plat_sysinfo_1205= ------------------------------------------------------------
notes_plat_sysinfo_1210= 10. who -r
notes_plat_sysinfo_1215=   run-level 5 Feb 8 01:38
notes_plat_sysinfo_1220=
notes_plat_sysinfo_1225= ------------------------------------------------------------
notes_plat_sysinfo_1230= 11. Systemd service manager version: systemd 255 (255.4-1ubuntu8)
notes_plat_sysinfo_1235=   Default Target  Status
notes_plat_sysinfo_1240=   graphical       degraded
notes_plat_sysinfo_1245=
notes_plat_sysinfo_1250= ------------------------------------------------------------
notes_plat_sysinfo_1255= 12. Failed units, from systemctl list-units --state=failed
notes_plat_sysinfo_1260=     UNIT                                 LOAD   ACTIVE SUB    DESCRIPTION
notes_plat_sysinfo_1265=   * systemd-networkd-wait-online.service loaded failed failed Wait for Network to be Configured
notes_plat_sysinfo_1270=   Legend: LOAD   -> Reflects whether the unit definition was properly loaded.
notes_plat_sysinfo_1275=           ACTIVE -> The high-level unit activation state, i.e. generalization of SUB.
notes_plat_sysinfo_1280=           SUB    -> The low-level unit activation state, values depend on unit type.
notes_plat_sysinfo_1285=   1 loaded units listed.
notes_plat_sysinfo_1290=
notes_plat_sysinfo_1295= ------------------------------------------------------------
notes_plat_sysinfo_1300= 13. Services, from systemctl list-unit-files
notes_plat_sysinfo_1305=   STATE            UNIT FILES
notes_plat_sysinfo_1310=   enabled          ModemManager apparmor apport blk-availability cloud-config cloud-final cloud-init
notes_plat_sysinfo_1315=                    cloud-init-local console-setup cron dmesg e2scrub_reap finalrd getty@ gpu-manager
notes_plat_sysinfo_1320=                    grub-common grub-initrd-fallback keyboard-setup lvm2-monitor multipathd
notes_plat_sysinfo_1325=                    networkd-dispatcher open-iscsi open-vm-tools pollinate rsyslog secureboot-db setvtrgb
notes_plat_sysinfo_1330=                    snapd sysstat systemd-networkd systemd-networkd-wait-online systemd-pstore
notes_plat_sysinfo_1335=                    systemd-resolved systemd-timesyncd thermald tuned ua-reboot-cmds ubuntu-advantage udisks2
notes_plat_sysinfo_1340=                    ufw unattended-upgrades vgauth
notes_plat_sysinfo_1345=   enabled-runtime  netplan-ovs-cleanup systemd-fsck-root systemd-remount-fs
notes_plat_sysinfo_1350=   disabled         console-getty debug-shell iscsid nftables rsync serial-getty@ ssh
notes_plat_sysinfo_1355=                    systemd-boot-check-no-failures systemd-confext systemd-network-generator
notes_plat_sysinfo_1360=                    systemd-networkd-wait-online@ systemd-pcrlock-file-system systemd-pcrlock-firmware-code
notes_plat_sysinfo_1365=                    systemd-pcrlock-firmware-config systemd-pcrlock-machine-id systemd-pcrlock-make-policy
notes_plat_sysinfo_1370=                    systemd-pcrlock-secureboot-authority systemd-pcrlock-secureboot-policy systemd-sysext
notes_plat_sysinfo_1375=                    systemd-time-wait-sync upower
notes_plat_sysinfo_1380=   indirect         systemd-sysupdate systemd-sysupdate-reboot uuidd
notes_plat_sysinfo_1385=   masked           cryptdisks cryptdisks-early hwclock multipath-tools-boot screen-cleanup sudo x11-common
notes_plat_sysinfo_1390=
notes_plat_sysinfo_1395= ------------------------------------------------------------
notes_plat_sysinfo_1400= 14. Linux kernel boot-time arguments, from /proc/cmdline
notes_plat_sysinfo_1405=   BOOT_IMAGE=/boot/vmlinuz-6.8.0-52-generic
notes_plat_sysinfo_1410=   root=UUID=ed2b24dd-ec95-4a2c-a13c-e4eb5ff96574
notes_plat_sysinfo_1415=   ro
notes_plat_sysinfo_1420=
notes_plat_sysinfo_1425= ------------------------------------------------------------
notes_plat_sysinfo_1430= 15. cpupower frequency-info
notes_plat_sysinfo_1435=   analyzing CPU 241:
notes_plat_sysinfo_1440=     current policy: frequency should be within 1.50 GHz and 2.70 GHz.
notes_plat_sysinfo_1445=                     The governor "performance" may decide which speed to use
notes_plat_sysinfo_1450=                     within this range.
notes_plat_sysinfo_1455=     boost state support:
notes_plat_sysinfo_1460=       Supported: yes
notes_plat_sysinfo_1465=       Active: yes
notes_plat_sysinfo_1470=       Boost States: 0
notes_plat_sysinfo_1475=       Total States: 3
notes_plat_sysinfo_1480=       Pstate-P0:  2700MHz
notes_plat_sysinfo_1485=
notes_plat_sysinfo_1490= ------------------------------------------------------------
notes_plat_sysinfo_1495= 16. tuned-adm active
notes_plat_sysinfo_1500=   Current active profile: latency-performance
notes_plat_sysinfo_1505=
notes_plat_sysinfo_1510= ------------------------------------------------------------
notes_plat_sysinfo_1515= 17. sysctl
notes_plat_sysinfo_1520=   kernel.numa_balancing               1
notes_plat_sysinfo_1525=   kernel.randomize_va_space           0
notes_plat_sysinfo_1530=   vm.compaction_proactiveness        20
notes_plat_sysinfo_1535=   vm.dirty_background_bytes           0
notes_plat_sysinfo_1540=   vm.dirty_background_ratio           3
notes_plat_sysinfo_1545=   vm.dirty_bytes                      0
notes_plat_sysinfo_1550=   vm.dirty_expire_centisecs        3000
notes_plat_sysinfo_1555=   vm.dirty_ratio                      8
notes_plat_sysinfo_1560=   vm.dirty_writeback_centisecs      500
notes_plat_sysinfo_1565=   vm.dirtytime_expire_seconds     43200
notes_plat_sysinfo_1570=   vm.extfrag_threshold              500
notes_plat_sysinfo_1575=   vm.min_unmapped_ratio               1
notes_plat_sysinfo_1580=   vm.nr_hugepages                     0
notes_plat_sysinfo_1585=   vm.nr_hugepages_mempolicy           0
notes_plat_sysinfo_1590=   vm.nr_overcommit_hugepages          0
notes_plat_sysinfo_1595=   vm.swappiness                       1
notes_plat_sysinfo_1600=   vm.watermark_boost_factor       15000
notes_plat_sysinfo_1605=   vm.watermark_scale_factor          10
notes_plat_sysinfo_1610=   vm.zone_reclaim_mode                1
notes_plat_sysinfo_1615=
notes_plat_sysinfo_1620= ------------------------------------------------------------
notes_plat_sysinfo_1625= 18. /sys/kernel/mm/transparent_hugepage
notes_plat_sysinfo_1630=   defrag          [always] defer defer+madvise madvise never
notes_plat_sysinfo_1635=   enabled         [always] madvise never
notes_plat_sysinfo_1640=   hpage_pmd_size  2097152
notes_plat_sysinfo_1645=   shmem_enabled   always within_size advise [never] deny force
notes_plat_sysinfo_1650=
notes_plat_sysinfo_1655= ------------------------------------------------------------
notes_plat_sysinfo_1660= 19. /sys/kernel/mm/transparent_hugepage/khugepaged
notes_plat_sysinfo_1665=   alloc_sleep_millisecs   60000
notes_plat_sysinfo_1670=   defrag                      1
notes_plat_sysinfo_1675=   max_ptes_none             511
notes_plat_sysinfo_1680=   max_ptes_shared           256
notes_plat_sysinfo_1685=   max_ptes_swap              64
notes_plat_sysinfo_1690=   pages_to_scan            4096
notes_plat_sysinfo_1695=   scan_sleep_millisecs    10000
notes_plat_sysinfo_1700=
notes_plat_sysinfo_1705= ------------------------------------------------------------
notes_plat_sysinfo_1710= 20. OS release
notes_plat_sysinfo_1715=   From /etc/*-release /etc/*-version
notes_plat_sysinfo_1720=   os-release Ubuntu 24.04 LTS
notes_plat_sysinfo_1725=
notes_plat_sysinfo_1730= ------------------------------------------------------------
notes_plat_sysinfo_1735= 21. Disk information
notes_plat_sysinfo_1740= SPEC is set to: /mnt/ramdisk/cpu2017-1.1.9-aocc500-znerv5_A1
notes_plat_sysinfo_1745=   Filesystem     Type   Size  Used Avail Use% Mounted on
notes_plat_sysinfo_1750=   tmpfs          tmpfs  130G  3.3G  127G   3% /mnt/ramdisk
notes_plat_sysinfo_1755=
notes_plat_sysinfo_1760= ------------------------------------------------------------
notes_plat_sysinfo_1765= 22. /sys/devices/virtual/dmi/id
notes_plat_sysinfo_1770=     Vendor:         Dell Inc.
notes_plat_sysinfo_1775=     Product:        PowerEdge XE7745
notes_plat_sysinfo_1780=     Product Family: PowerEdge
notes_plat_sysinfo_1785=     Serial:         1234567
notes_plat_sysinfo_1790=
notes_plat_sysinfo_1795= ------------------------------------------------------------
notes_plat_sysinfo_1800= 23. dmidecode
notes_plat_sysinfo_1805=   Additional information from dmidecode 3.5 follows.  WARNING: Use caution when you interpret this section.
notes_plat_sysinfo_1810=   The 'dmidecode' program reads system data which is "intended to allow hardware to be accurately
notes_plat_sysinfo_1815=   determined", but the intent may not be met, as there are frequent changes to hardware, firmware, and the
notes_plat_sysinfo_1820=   "DMTF SMBIOS" standard.
notes_plat_sysinfo_1825=   Memory:
notes_plat_sysinfo_1830=     1x 80AD000080AD HMCG94AHBRA277N 64 GB 2 rank 6400, configured at 6000
notes_plat_sysinfo_1835=     19x 80AD000080AD HMCG94AHBRA480N 64 GB 2 rank 6400, configured at 6000
notes_plat_sysinfo_1840=     4x 80CE000080CE M321R8GA0PB2-CCPEC 64 GB 2 rank 6400, configured at 6000
notes_plat_sysinfo_1845=
notes_plat_sysinfo_1850=
notes_plat_sysinfo_1855= ------------------------------------------------------------
notes_plat_sysinfo_1860= 24. BIOS
notes_plat_sysinfo_1865= (This section combines info from /sys/devices and dmidecode.)
notes_plat_sysinfo_1870=    BIOS Vendor:       Dell Inc.
notes_plat_sysinfo_1875=    BIOS Version:      1.0.3
notes_plat_sysinfo_1880=    BIOS Date:         01/14/2025
notes_plat_sysinfo_1885=    BIOS Revision:     1.0
hw_cpu_name        = AMD EPYC 9755
hw_disk            = 130 GB  add more disk info here
hw_nchips          = 2
hw_ncores          = 256
hw_nthreadspercore = 1
prepared_by        = root  (is never output, only tags rawfile)
sw_file            = tmpfs
sw_os001           = Ubuntu 24.04 LTS
sw_state           = Run level 5 (add definition here)
# End of settings added by sysinfo_program


648.exchange2_s:
# The following setting was inserted automatically as a result of
# post-run basepeak application.
basepeak = 1


631.deepsjeng_s:
# The following setting was inserted automatically as a result of
# post-run basepeak application.
basepeak = 1


620.omnetpp_s:
# The following setting was inserted automatically as a result of
# post-run basepeak application.
basepeak = 1


602.gcc_s:
# The following setting was inserted automatically as a result of
# post-run basepeak application.
basepeak = 1


600.perlbench_s:
# The following setting was inserted automatically as a result of
# post-run basepeak application.
basepeak = 1