X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/4efdee0ba07bce3d24e76a529e329c17634a07a6..2a0eac257242d9e2ab47acbb59e5e092a1f5cc10:/cookbooks/hardware/attributes/default.rb?ds=inline diff --git a/cookbooks/hardware/attributes/default.rb b/cookbooks/hardware/attributes/default.rb index f27074082..d2c1b36bd 100644 --- a/cookbooks/hardware/attributes/default.rb +++ b/cookbooks/hardware/attributes/default.rb @@ -1,13 +1,10 @@ -default[:hardware][:modules] = if node[:lsb][:release].to_f >= 16.04 - %w[lp] - else - %w[loop lp rtc] - end - +default[:hardware][:modules] = %w[lp] +default[:hardware][:blacklisted_modules] = %w[] default[:hardware][:grub][:cmdline] = %w[nomodeset] default[:hardware][:sensors] = {} - -default[:hardware][:mcelog][:enabled] = node[:lsb][:release].to_f < 18.04 +default[:hardware][:hwmon] = {} +default[:hardware][:ipmi][:excluded_sensors] = [] +default[:hardware][:ipmi][:custom_args] = [] if node[:dmi] && node[:dmi][:system] case node[:dmi][:system][:manufacturer] @@ -15,9 +12,14 @@ if node[:dmi] && node[:dmi][:system] default[:apt][:sources] |= ["management-component-pack"] case node[:dmi][:system][:product_name] - when "ProLiant DL360 G6", "ProLiant DL360 G7" + when "ProLiant DL360 G6", "ProLiant DL360 G7", "ProLiant SE326M1R2" default[:hardware][:sensors][:"power_meter-*"][:power][:power1] = { :ignore => true } end + + case node[:dmi][:system][:product_name] + when "ProLiant DL360 G6", "ProLiant DL360 G7", "ProLiant SE326M1R2", "ProLiant DL360e Gen8", "ProLiant DL360p Gen8" + default[:hardware][:ipmi][:custom_args] |= ["--workaround-flags=discretereading"] + end end end @@ -37,6 +39,10 @@ end if node[:kernel][:modules].include?("ipmi_si") default[:hardware][:modules] |= ["ipmi_devintf"] + + if node[:kernel][:modules].include?("acpi_power_meter") + default[:hardware][:modules] |= ["acpi_ipmi"] + end end if File.exist?("/proc/xen") @@ -44,3 +50,20 @@ if File.exist?("/proc/xen") elsif node[:kernel][:modules].include?("i6300esb") default[:hardware][:watchdog] = "none" end + +if File.exist?("/sys/devices/system/cpu/cpu0/cpufreq/scaling_governor") && + File.read("/sys/devices/system/cpu/cpu0/cpufreq/scaling_governor").chomp == "ondemand" + default[:sysfs][:cpufreq_ondemand][:comment] = "Tune the ondemand CPU frequency governor" + default[:sysfs][:cpufreq_ondemand][:parameters][:"devices/system/cpu/cpufreq/ondemand/up_threshold"] = "25" + default[:sysfs][:cpufreq_ondemand][:parameters][:"devices/system/cpu/cpufreq/ondemand/sampling_down_factor"] = "100" +end + +energy_perf_bias = Dir.glob("/sys/devices/system/cpu/cpu*/power/energy_perf_bias") + +unless energy_perf_bias.empty? + default[:sysfs][:cpu_power_energy_perf_bias][:comment] = "Set CPU Energy-Performance Bias Preference to performance" + + energy_perf_bias.sort.each do |path| + default[:sysfs][:cpu_power_energy_perf_bias][:parameters][path.sub(%r{^/sys/}, "")] = "0" + end +end