Ubuntu 20.04 で AMD GPU とメモリのクロックと電圧を変更できない

Ubuntu 20.04 で AMD GPU とメモリのクロックと電圧を変更できない

Ubuntu 18.04 LTS から Ubuntu 20.04 LTS にアップグレードした後、Sapphire Radeon RX 580 Pulse または Sapphire Radeon RX 580 Nitro+ SE のクロックと電圧設定を微調整できなくなりました。ファンと電力制限の変更には問題はありません。amdgpu ドライバー 20.30-1109583 を使用しています。amdgpu ドライバー 20.20 を使用しようとしましたが、同じ問題が発生しました。

私は手動で、Bash スクリプトを使用して、Wattman_GTK を使用して、amdgpu-clocks を使用して、CoreCtrl を使用しようとしましたが、クラッシュしました。

/etc/default/grub を変更して以下を含めました:

GRUB_CMDLINE_LINUX_DEFAULT="quiet splash amdgpu.ppfeaturemask=0xffffffff"

そしてまた試した

GRUB_CMDLINE_LINUX_DEFAULT="quiet splash radeon.si_support=0 amdgpu.si_support=1 amdgpu.dpm=1 amdgpu.ppfeaturemask=0xffffffff"

これが私の Bash スクリプトです:

#!/bin/bash
# Get path for card 1
card_path=`readlink -f /sys/class/drm/card1/device`

echo "Path for card: $card_path"
echo "Initial values for card:"
echo "Power limit: $(cat $card_path/hwmon/hwmon2/power1_cap)"
echo "Fan settings: $(cat $card_path/hwmon/hwmon2/pwm1)"
pwm1_max=`cat $card_path/hwmon/hwmon2/pwm1_max`
echo "pwm1_max: $pwm1_max"
echo "GPU and memory clocks and voltages"
echo "$(cat $card_path/power_dpm_force_performance_level)"
echo "$(cat $card_path/pp_od_clk_voltage)"
echo " "

# Set power limit

echo "Setting card power limit:"
echo 101000000 > $card_path/hwmon/hwmon2/power1_cap

echo " "

# Set GPU and mem clocks and voltages

echo "Setting GPU and Mem clocks and voltages:"
echo manual > $card_path/power_dpm_force_performance_level

echo 's 0 300 750' > $card_path/pp_od_clk_voltage
echo 's 1 751 793' > $card_path/pp_od_clk_voltage
echo 's 2 848 806' > $card_path/pp_od_clk_voltage
echo 's 3 858 812' > $card_path/pp_od_clk_voltage
echo 's 4 900 820' > $card_path/pp_od_clk_voltage
echo 's 5 1059 840' > $card_path/pp_od_clk_voltage
echo 's 6 1194 880' > $card_path/pp_od_clk_voltage
echo 's 7 1280 890' > $card_path/pp_od_clk_voltage

echo 'm 0 300 750' > $card_path/pp_od_clk_voltage
echo 'm 1 1000 800' > $card_path/pp_od_clk_voltage
echo 'm 2 2215 895' > $card_path/pp_od_clk_voltage

echo c > $card_path/pp_od_clk_voltage

# Set Fan
echo " "
echo "Setting Fan:"
echo 1 > $card_path/hwmon/hwmon2/pwm1_enable
pwr_prc=$((pwm1_max * 7/10))
echo "$pwr_prc"
echo $pwr_prc > $card_path/hwmon/hwmon2/pwm1



# Check values 

echo " "
echo "Check settings"
echo "Power limit: $(cat $card_path/hwmon/hwmon2/power1_cap)"
echo " "
echo "Fan settings: $(cat $card_path/hwmon/hwmon2/pwm1)"
echo " "
echo "Clocks and voltages: "
echo "$(cat $card_path/power_dpm_force_performance_level)"
echo "$(cat $card_path/pp_od_clk_voltage)"

スクリプトを実行するには

sudo sh -c ./card1.sh

結果:

Initial values for card:
Power limit: 101000000
Fan settings: 173
pwm1_max: 255
GPU and memory clocks and voltages
manual
OD_SCLK:
0:        300MHz        750mV
1:        751MHz        793mV
2:       1048MHz       1006mV
3:       1158MHz       1112mV
4:       1240MHz       1150mV
5:       1309MHz       1150mV
6:       1364MHz       1150mV
7:       1430MHz       1150mV
OD_MCLK:
0:        300MHz        750mV
1:       1000MHz        800mV
2:       2100MHz        950mV
OD_RANGE:
SCLK:     300MHz       2000MHz
MCLK:     300MHz       2250MHz
VDDC:     750mV        1200mV
 
Setting card power limit:
 
Setting GPU and Mem clocks and voltages:
./card1.sh: line 28: echo: write error: Invalid argument
./card1.sh: line 29: echo: write error: Invalid argument
./card1.sh: line 30: echo: write error: Invalid argument
./card1.sh: line 31: echo: write error: Invalid argument
./card1.sh: line 32: echo: write error: Invalid argument
./card1.sh: line 33: echo: write error: Invalid argument
./card1.sh: line 34: echo: write error: Invalid argument
./card1.sh: line 35: echo: write error: Invalid argument
./card1.sh: line 37: echo: write error: Invalid argument
./card1.sh: line 38: echo: write error: Invalid argument
./card1.sh: line 39: echo: write error: Invalid argument
./card1.sh: line 41: echo: write error: Invalid argument
 
Setting Fan:
178
 
Check settings
Power limit: 101000000
 
Fan settings: 173
 
Clocks and voltages: 
manual
OD_SCLK:
0:        300MHz        750mV
1:        751MHz        793mV
2:       1048MHz       1006mV
3:       1158MHz       1112mV
4:       1240MHz       1150mV
5:       1309MHz       1150mV
6:       1364MHz       1150mV
7:       1430MHz       1150mV
OD_MCLK:
0:        300MHz        750mV
1:       1000MHz        800mV
2:       2100MHz        950mV
OD_RANGE:
SCLK:     300MHz       2000MHz
MCLK:     300MHz       2250MHz
VDDC:     750mV        1200mV

Wattman_GTK と amdgpu-clocks でもエラーが発生しました:

write error: Invalid argument

スクリプトを実行するには

$sudo sh card1.sh

「echo: 書き込みエラー: 無効な引数」の代わりに、

echo: echo: I/O error

これは、コマンド ラインからクロックと電圧を変更しようとした場合にも発生します。

$sudo echo 's 7 1280 895' > /sys/devices/pci0000:00/0000:00:1c.7/0000:0d:00.0/pp_od_clk_voltage

その結果は次のようになります。

-bash: /sys/devices/pci0000:00/0000:00:1c.7/0000:0d:00.0/pp_od_clk_voltage: Permission denied

答え1

デフォルトのカーネル (5.4) でも同じ問題が発生しました。カーネルをエッジ カーネル (linux-generic-hwe-20.04-edge) に更新すると、問題は解消されました。

答え2

これは、Radeon VII 20.04とドライバー20.45で動作します。

すべてのコアクロックレベルの変更:

echo 's 0 300 750' > $card_path/pp_od_clk_voltage

に:

echo 'vc 0 300 750' > $card_path/pp_od_clk_voltage

メモリ レベルには最大周波数の設定が 1 つしかないため、以下を削除します。

echo 'm 0 300 750' > $card_path/pp_od_clk_voltage
echo 'm 1 1000 800' > $card_path/pp_od_clk_voltage

そして変更:

echo 'm 2 2215 895' > $card_path/pp_od_clk_voltage

に:

echo 'm 1 2215' > $card_path/pp_od_clk_voltage

答え3

私も同じ問題を抱えていましたが、二重引用符( ")を単純な引用符( ')に変更したところ、問題なく動作しました。

IEの変更:

echo "s 0 300 750" > /sys/class/drm/card0/device/pp_od_clk_voltage

に:

echo 's 0 300 750' > /sys/class/drm/card0/device/pp_od_clk_voltage

お役に立てれば。

関連情報