View previous topic :: View next topic |
Author |
Message |
Anard Apprentice
Joined: 01 Oct 2020 Posts: 244
|
Posted: Sat Dec 14, 2024 2:41 pm Post subject: [RX570] Contrôle de la température (RESOLU) |
|
|
Bonjour,
Je viens d'installer une carte graphique RX570 (Sapphire ITX). Celle-ci semble bien supportée dans l'ensemble.
En revanche, j'ai l'impression que le ventilateur n'est pas contrôlé correctement.
Celui-ci ne tourne pas, pourtant il est indiqué par sensors qu'il tourne :
Code: | $ cat sensors
[...]
amdgpu-pci-0100
Adapter: PCI adapter
vddgfx: 900.00 mV
Ventilateur GPU: 1426 RPM (min = 0 RPM, max = 3500 RPM)
edge: +54.0°C (crit = +94.0°C, hyst = -273.1°C)
PPT: 22.01 W (cap = 120.00 W)
pwm1: 0%
sclk: 404 MHz
mclk: 2 GHz
|
En fait, les réglages d'origine définissent un PWM toujour trop faible pour déclencher le ventilateur, même au-dessus de 50°C.
J'ai essayé de lancer pwmconfig, il parvient bien à le faire tourner à vitesse maximale (~3600 tr/min indiqué) puis l'arrêter temporairement mais quand je lance un test, rien ne se passe :
Code: | $ sudo pwmconfig
# pwmconfig version 3.6.2
This program will search your sensors for pulse width modulation (pwm)
controls, and test each one to see if it controls a fan on
your motherboard. Note that many motherboards do not have pwm
circuitry installed, even if your sensor chip supports pwm.
We will attempt to briefly stop each fan using the pwm controls.
The program will attempt to restore each fan to full speed
after testing. However, it is ** very important ** that you
physically verify that the fans have been to full speed
after the program has completed.
Found the following devices:
hwmon0 is acpitz
hwmon1 is drivetemp
hwmon10 is hid_1e:d8:aa:a4:99:41_battery
hwmon2 is drivetemp
hwmon3 is drivetemp
hwmon4 is drivetemp
hwmon5 is drivetemp
hwmon6 is drivetemp
hwmon7 is coretemp
hwmon8 is it8620
hwmon9 is amdgpu
Found the following PWM controls:
hwmon8/pwm1 current value: 70
hwmon8/pwm1 is currently setup for automatic speed control.
In general, automatic mode is preferred over manual mode, as
it is more efficient and it reacts faster. Are you sure that
you want to setup this output for manual control? (n)
hwmon8/pwm2 current value: 70
hwmon8/pwm2 is currently setup for automatic speed control.
In general, automatic mode is preferred over manual mode, as
it is more efficient and it reacts faster. Are you sure that
you want to setup this output for manual control? (n)
hwmon8/pwm3 current value: 70
hwmon8/pwm3 is currently setup for automatic speed control.
In general, automatic mode is preferred over manual mode, as
it is more efficient and it reacts faster. Are you sure that
you want to setup this output for manual control? (n)
hwmon8/pwm4 current value: 70
hwmon8/pwm4 is currently setup for automatic speed control.
In general, automatic mode is preferred over manual mode, as
it is more efficient and it reacts faster. Are you sure that
you want to setup this output for manual control? (n)
hwmon8/pwm5 current value: 0
hwmon8/pwm5 is currently setup for automatic speed control.
In general, automatic mode is preferred over manual mode, as
it is more efficient and it reacts faster. Are you sure that
you want to setup this output for manual control? (n)
hwmon9/pwm1 current value: 0
hwmon9/pwm1 is currently setup for automatic speed control.
In general, automatic mode is preferred over manual mode, as
it is more efficient and it reacts faster. Are you sure that
you want to setup this output for manual control? (n) y
Giving the fans some time to reach full speed...
Found the following fan sensors:
hwmon8/fan1_input current speed: 604 RPM
hwmon8/fan2_input current speed: 1285 RPM
hwmon8/fan3_input current speed: 437 RPM
hwmon8/fan4_input current speed: 0 ... skipping!
hwmon8/fan5_input current speed: 0 ... skipping!
hwmon9/fan1_input current speed: 3578 RPM
Warning!!! This program will stop your fans, one at a time,
for approximately 5 seconds each!!!
This may cause your processor temperature to rise!!!
If you do not want to do this hit control-C now!!!
Hit return to continue:
Testing pwm control hwmon9/pwm1 ...
hwmon8/fan1_input ... speed was 604 now 607
no correlation
hwmon8/fan2_input ... speed was 1285 now 1225
no correlation
hwmon8/fan3_input ... speed was 437 now 436
no correlation
hwmon9/fan1_input ... speed was 3578 now 3116
no correlation
No correlations were detected.
There is either no fan connected to the output of hwmon9/pwm1,
or the connected fan has no rpm-signal connected to one of
the tested fan sensors. (Note: not all motherboards have
the pwm outputs connected to the fan connectors,
check out the hardware database on http://www.almico.com/forumindex.php)
Did you see/hear a fan stopping during the above test (n)? y
Testing is complete.
Please verify that all fans have returned to their normal speed.
The fancontrol script can automatically respond to temperature changes
of your system by changing fanspeeds.
Do you want to set up its configuration file now (y)?
What should be the path to your fancontrol config file (/etc/fancontrol)?
Loading configuration from /etc/fancontrol ...
Device path of hwmon5 has changed
Device path of hwmon6 has changed
Device name of hwmon5 has changed
Device name of hwmon6 has changed
Configuration appears to be outdated, discarded
Select fan output to configure, or other action:
1) hwmon9/pwm1 3) Just quit 5) Show configuration
2) Change INTERVAL 4) Save and quit
select (1-n): 1
Devices:
hwmon0 is acpitz
hwmon1 is drivetemp
hwmon10 is hid_1e:d8:aa:a4:99:41_battery
hwmon2 is drivetemp
hwmon3 is drivetemp
hwmon4 is drivetemp
hwmon5 is drivetemp
hwmon6 is drivetemp
hwmon7 is coretemp
hwmon8 is it8620
hwmon9 is amdgpu
Current temperature readings are as follows:
hwmon0/temp1_input 27
hwmon0/temp2_input 29
hwmon1/temp1_input 29
hwmon2/temp1_input 29
hwmon3/temp1_input 31
hwmon4/temp1_input 31
hwmon5/temp1_input 31
hwmon6/temp1_input 29
hwmon7/temp1_input 33
hwmon7/temp2_input 32
hwmon7/temp3_input 32
hwmon7/temp4_input 31
hwmon7/temp5_input 31
hwmon8/temp1_input 27
hwmon8/temp2_input -128
hwmon8/temp3_input 26
hwmon8/temp4_input 27
hwmon8/temp5_input 41
hwmon8/temp6_input 45
hwmon9/temp1_input 25
Select a temperature sensor as source for hwmon9/pwm1:
1) hwmon0/temp1_input
2) hwmon0/temp2_input
3) hwmon1/temp1_input
4) hwmon2/temp1_input
5) hwmon3/temp1_input
6) hwmon4/temp1_input
7) hwmon5/temp1_input
8) hwmon6/temp1_input
9) hwmon7/temp1_input
10) hwmon7/temp2_input
11) hwmon7/temp3_input
12) hwmon7/temp4_input
13) hwmon7/temp5_input
14) hwmon8/temp1_input
15) hwmon8/temp2_input
16) hwmon8/temp3_input
17) hwmon8/temp4_input
18) hwmon8/temp5_input
19) hwmon8/temp6_input
20) hwmon9/temp1_input
21) None (Do not affect this PWM output)
select (1-n): 20
Enter the low temperature (degree C)
below which the fan should spin at minimum speed (20):
Enter the high temperature (degree C)
over which the fan should spin at maximum speed (60): 65
Enter the minimum PWM value (0-255)
at which the fan STOPS spinning (press t to test) (100): t
Now we decrease the PWM value to figure out the lowest usable value.
We will use a slightly greater value as the minimum speed.
[...]
|
Puis plus rien…
Pourriez-vous m'aider à le faire fonctionner correctement SVP ? Peut-être me manque-t-il des drivers ?
Merci beaucoup _________________ "iMack" : GA-H97M-D3H, Intel i7 4790, 16Go DDR3, Sapphire RX570 4Go, 2x SSD 256Go, HDD 500Go + Zpool 3x2To / Clover - macOS Mojave / Gentoo-Xfce
Last edited by Anard on Sun Jan 05, 2025 8:06 am; edited 2 times in total |
|
Back to top |
|
|
Anard Apprentice
Joined: 01 Oct 2020 Posts: 244
|
Posted: Sat Dec 14, 2024 3:39 pm Post subject: |
|
|
J'ai testé manuellement en écrivant ceci, le ventilateur répond bien à ma demande :
Code: | # cd /sys/class/drm/card0/device/hwmon/hwmon9
# echo 1 > fan1_enable
# echo 100 > pwm1
# echo 150 > pwm1
# echo 200 > pwm1
# echo 255 > pwm1 |
Ce qui m'a permis de créer un /etc/fancontrol qui fonctionne correctement. Après avoir démarré fancontrol, le ventilateur semble géré correctement.
Code: | $ cat /etc/fancontrol
# Configuration file generated by pwmconfig, changes will be lost
INTERVAL=10
DEVPATH=hwmon9=devices/pci0000:00/0000:00:01.0/0000:01:00.0
DEVNAME=hwmon9=amdgpu
FCTEMPS=hwmon9/pwm1=hwmon9/temp1_input
FCFANS= hwmon9/pwm1=
MINTEMP=hwmon9/pwm1=20
MAXTEMP=hwmon9/pwm1=65
MINSTART=hwmon9/pwm1=150
MINSTOP=hwmon9/pwm1=100
|
Mais comment se fait-il que celui-ci ne fonctionnait pas correctement à l'origine ? En effet, que ce soit pour le ventilo CPU et pour les ventilos du boîtier, ils étaient gérés automatiquement sans avoir besoin ni de configurer ni de démarrer fancontrol... Aussi, quand je cherchais la corrélation entre la vitesse et la valeur PWM, pwmconfig était capable de me faire une courbe de réponse du ventilateur concerné, apparemment il n'y parvient pas pour le GPU. _________________ "iMack" : GA-H97M-D3H, Intel i7 4790, 16Go DDR3, Sapphire RX570 4Go, 2x SSD 256Go, HDD 500Go + Zpool 3x2To / Clover - macOS Mojave / Gentoo-Xfce |
|
Back to top |
|
|
Anard Apprentice
Joined: 01 Oct 2020 Posts: 244
|
Posted: Sun Dec 15, 2024 7:26 am Post subject: |
|
|
Aussi, je retrouve maintenant le souci que j'avais eu lors de ma première tentative d'utilisation de fancontrol sous Gentoo : le service crashe lors de la mise en veille du système…
https://forums.gentoo.org/viewtopic-t-1148000-highlight-fancontrol.html _________________ "iMack" : GA-H97M-D3H, Intel i7 4790, 16Go DDR3, Sapphire RX570 4Go, 2x SSD 256Go, HDD 500Go + Zpool 3x2To / Clover - macOS Mojave / Gentoo-Xfce |
|
Back to top |
|
|
Anard Apprentice
Joined: 01 Oct 2020 Posts: 244
|
Posted: Mon Dec 23, 2024 9:18 am Post subject: |
|
|
Rebonjour.
Je ne comprends pas comment m'en sortir.
En dépannage, même si ce n'est pas très "propre", j'ai créé un petit script pour checker l'existence du service fancontrol et le redémarrer s'il est bloqué (ce qui arrive suite à chaque mise en veille).
Code: | $ cat /usr/local/bin/check-fancontrol.sh
#!/bin/bash
# check if service fancontrol exists
/usr/bin/rc-service -e fancontrol
if [ $? -eq 0 ]; then
# check if fancontrol is needed
if [[ $(/usr/bin/rc-update show | grep fancontrol) ]]; then
# restart if crashed
/usr/bin/rc-service -c fancontrol restart
fi
fi |
Celui-ci fonctionne correctement si je le lance manuellement. J'ai ajouté ce script au crontab root pour vérifier l'état du service et le redémarrer si nécessaire toutes les 10 minutes :
Code: | $ sudo crontab -l
Mot de passe :
# Trim SSD
0 14 * * 1 /usr/bin/fstrim -v /
# Check fancontrol & restart if needed
*/10 * * * * /usr/local/bin/check-fancontrol.sh
#Back In Time system entry, this will be edited by the gui:
0 13 * * * /usr/sbin/nice -n19 /usr/sbin/ionice -c2 -n7 /usr/sbin/backintime backup-job >/dev/null
|
Malheureusement, le script est bien éxecuté mais le service fancontrol reste crashé …
Pourriez-vous m'aider, je ne comprends plus ce que je peux faire… _________________ "iMack" : GA-H97M-D3H, Intel i7 4790, 16Go DDR3, Sapphire RX570 4Go, 2x SSD 256Go, HDD 500Go + Zpool 3x2To / Clover - macOS Mojave / Gentoo-Xfce |
|
Back to top |
|
|
Anard Apprentice
Joined: 01 Oct 2020 Posts: 244
|
Posted: Sat Dec 28, 2024 4:08 pm Post subject: |
|
|
...
Salut. Je suis un peu nul, alors j'ai demandé à ChatGPT de m'aider à mettre au point le script qui contrôlera le redémarrage de fancontrol en sortie de veille. Ca n'a pas été évident de trouver la bonne méthode, mais je pense que ce n'est pas si mal. On se base sur une règle udev qui détecte le réveil du port Ethernet.
Pouvez vous me dire ce que vous en pensez en tant qu'intelligence réelle ? Des suggestions pour améliorer la chose ?
Code: | $ cat /etc/udev/rules.d/99-resume.rules
SUBSYSTEM=="wakeup", ACTION=="remove", DEVPATH=="/devices/pci0000:00/0000:00:1c.2/*", RUN+="/usr/local/bin/check-fancontrol.sh -q"
$ cat /usr/local/bin/check-fancontrol.sh
#!/bin/bash
logFile="/var/log/resume.log"
first_log=1
# Parse options
for arg in "$@"; do
case $arg in
-h|--help)
echo "Usage: $0 [OPTIONS]"
echo "Options:"
echo " -q, --quiet Suppress log output."
echo " -h, --help Display this help message."
exit 0
;;
-q|--quiet)
logFile="/dev/null"
shift
;;
*)
shift
;;
esac
done
log() {
case $first_log in
0)
echo "WAKEUP : $1" >> "${logFile}"
;;
*)
first_log=0
echo "WAKEUP : $1" > "${logFile}"
;;
esac
}
check_sensors_ready() {
for i in {1..5}; do
if sensors > /dev/null 2>&1; then
log "Sensors ready"
return 0
else
log "Waiting for sensors to be ready ($i)"
sleep 5
fi
done
log "Sensors not ready after $i tries, aborting..."
return 1
}
restart_fancontrol() {
log "Restarting fancontrol"
/usr/bin/rc-service fancontrol zap >> "${logFile}" 2>&1
if [ $? -ne 0 ]; then
log "Failed to reset fancontrol service state."
return 2
fi
sleep 2
/usr/bin/rc-service fancontrol start >> "${logFile}" 2>&1
if [ $? -ne 0 ]; then
log "Failed to start fancontrol service."
return 3
fi
log "fancontrol service successfully restarted"
return 0
}
log "in progress"
# check if service fancontrol exists
/usr/bin/rc-service -e fancontrol
if [ $? -eq 0 ]; then
# check if fancontrol is needed
if [[ $(/usr/bin/rc-update show | grep fancontrol) ]]; then
if check_sensors_ready; then
restart_fancontrol
exit $?
else
exit 1
fi
fi
fi
log "finished"
exit 0 |
En tout cas ça semble bien fonctionner _________________ "iMack" : GA-H97M-D3H, Intel i7 4790, 16Go DDR3, Sapphire RX570 4Go, 2x SSD 256Go, HDD 500Go + Zpool 3x2To / Clover - macOS Mojave / Gentoo-Xfce |
|
Back to top |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
|