mb/{ibase/mb899,kontron/986lcd-m}: Use pnp_write_hwm5_index function

Change-Id: If30a17d053da8f0758085fc36469b564d46049cd
Signed-off-by: Elyes HAOUAS <ehaouas@noos.fr>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/35901
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Felix Held <felix-coreboot@felixheld.de>
This commit is contained in:
Elyes HAOUAS 2019-10-08 21:44:02 +02:00 committed by Felix Held
parent 7f9b90f0a6
commit edfe125bf9
2 changed files with 52 additions and 68 deletions

View file

@ -19,6 +19,7 @@
#include <console/console.h> #include <console/console.h>
#include <device/device.h> #include <device/device.h>
#include <pc80/mc146818rtc.h> #include <pc80/mc146818rtc.h>
#include <superio/hwm5_conf.h>
#include "superio_hwm.h" #include "superio_hwm.h"
@ -33,17 +34,6 @@
#define HWM_BASE 0x290 #define HWM_BASE 0x290
static void hwm_write(u8 reg, u8 value)
{
outb(reg, HWM_BASE + 0x05);
outb(value, HWM_BASE + 0x06);
}
static void hwm_bank(u8 bank)
{
hwm_write(0x4e, bank);
}
struct fan_speed { struct fan_speed {
u8 fan_in; u8 fan_in;
u16 fan_speed; u16 fan_speed;
@ -90,19 +80,19 @@ void hwm_setup(void)
//sysfan_temperature = FAN_TEMPERATURE_30DEGC; //sysfan_temperature = FAN_TEMPERATURE_30DEGC;
//get_option(&sysfan_temperature, "sysfan_temperature"); //get_option(&sysfan_temperature, "sysfan_temperature");
// hwm_write(0x31, 0x20); // AVCC high limit // pnp_write_hwm5_index(HWM_BASE, 0x31, 0x20); // AVCC high limit
// hwm_write(0x34, 0x06); // VIN2 low limit // pnp_write_hwm5_index(HWM_BASE, 0x34, 0x06); // VIN2 low limit
hwm_bank(0); pnp_write_hwm5_index(HWM_BASE, 0x4e, 0);
hwm_write(0x59, 0x20); // Diode Selection pnp_write_hwm5_index(HWM_BASE, 0x59, 0x20); // Diode Selection
hwm_write(0x5d, 0x0f); // All Sensors Diode, not Thermistor pnp_write_hwm5_index(HWM_BASE, 0x5d, 0x0f); // All Sensors Diode, not Thermistor
hwm_bank(4); pnp_write_hwm5_index(HWM_BASE, 0x4e, 4);
hwm_write(0x54, 0xf1); // SYSTIN temperature offset pnp_write_hwm5_index(HWM_BASE, 0x54, 0xf1); // SYSTIN temperature offset
hwm_write(0x55, 0x19); // CPUTIN temperature offset pnp_write_hwm5_index(HWM_BASE, 0x55, 0x19); // CPUTIN temperature offset
hwm_write(0x56, 0xfc); // AUXTIN temperature offset pnp_write_hwm5_index(HWM_BASE, 0x56, 0xfc); // AUXTIN temperature offset
hwm_bank(0x80); // Default pnp_write_hwm5_index(HWM_BASE, 0x4e, 0x80); // Default
u8 fan_config = 0; u8 fan_config = 0;
// 00 FANOUT is Manual Mode // 00 FANOUT is Manual Mode
@ -117,41 +107,43 @@ void hwm_setup(void)
case FAN_CRUISE_CONTROL_THERMAL: fan_config |= (1 << 2); break; case FAN_CRUISE_CONTROL_THERMAL: fan_config |= (1 << 2); break;
} }
// This register must be written first // This register must be written first
hwm_write(0x04, fan_config); pnp_write_hwm5_index(HWM_BASE, 0x04, fan_config);
switch (cpufan_control) { switch (cpufan_control) {
case FAN_CRUISE_CONTROL_SPEED: case FAN_CRUISE_CONTROL_SPEED: /* CPUFANIN target speed */
printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to %d RPM\n", printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to %d RPM\n",
fan_speeds[cpufan_speed].fan_speed); fan_speeds[cpufan_speed].fan_speed);
hwm_write(0x06, fan_speeds[cpufan_speed].fan_in); // CPUFANIN target speed pnp_write_hwm5_index(HWM_BASE, 0x06, fan_speeds[cpufan_speed].fan_in);
break; break;
case FAN_CRUISE_CONTROL_THERMAL: case FAN_CRUISE_CONTROL_THERMAL: /* CPUFANIN target temperature */
printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to activation at %d deg C/%d deg F\n", printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to activation at %d deg C/%d deg F\n",
temperatures[cpufan_temperature].deg_celsius, temperatures[cpufan_temperature].deg_celsius,
temperatures[cpufan_temperature].deg_fahrenheit); temperatures[cpufan_temperature].deg_fahrenheit);
hwm_write(0x06, temperatures[cpufan_temperature].deg_celsius); // CPUFANIN target temperature pnp_write_hwm5_index(HWM_BASE, 0x06,
temperatures[cpufan_temperature].deg_celsius);
break; break;
} }
switch (sysfan_control) { switch (sysfan_control) {
case FAN_CRUISE_CONTROL_SPEED: case FAN_CRUISE_CONTROL_SPEED: /* SYSFANIN target speed */
printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to %d RPM\n", printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to %d RPM\n",
fan_speeds[sysfan_speed].fan_speed); fan_speeds[sysfan_speed].fan_speed);
hwm_write(0x05, fan_speeds[sysfan_speed].fan_in); // SYSFANIN target speed pnp_write_hwm5_index(HWM_BASE, 0x05, fan_speeds[sysfan_speed].fan_in);
break; break;
case FAN_CRUISE_CONTROL_THERMAL: case FAN_CRUISE_CONTROL_THERMAL: /* SYSFANIN target temperature */
printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to activation at %d deg C/%d deg F\n", printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to activation at %d deg C/%d deg F\n",
temperatures[sysfan_temperature].deg_celsius, temperatures[sysfan_temperature].deg_celsius,
temperatures[sysfan_temperature].deg_fahrenheit); temperatures[sysfan_temperature].deg_fahrenheit);
hwm_write(0x05, temperatures[sysfan_temperature].deg_celsius); // SYSFANIN target temperature pnp_write_hwm5_index(HWM_BASE,
0x05, temperatures[sysfan_temperature].deg_celsius);
break; break;
} }
hwm_write(0x0e, 0x02); // Fan Output Step Down Time pnp_write_hwm5_index(HWM_BASE, 0x0e, 0x02); // Fan Output Step Down Time
hwm_write(0x0f, 0x02); // Fan Output Step Up Time pnp_write_hwm5_index(HWM_BASE, 0x0f, 0x02); // Fan Output Step Up Time
hwm_write(0x47, 0xaf); // FAN divisor register pnp_write_hwm5_index(HWM_BASE, 0x47, 0xaf); // FAN divisor register
hwm_write(0x4b, 0x84); // AUXFANIN speed divisor pnp_write_hwm5_index(HWM_BASE, 0x4b, 0x84); // AUXFANIN speed divisor
hwm_write(0x40, 0x01); // Init, but no SMI# pnp_write_hwm5_index(HWM_BASE, 0x40, 0x01); // Init, but no SMI#
} }

View file

@ -21,22 +21,12 @@
#include <drivers/intel/gma/int15.h> #include <drivers/intel/gma/int15.h>
#include <pc80/mc146818rtc.h> #include <pc80/mc146818rtc.h>
#include <arch/io.h> #include <arch/io.h>
#include <superio/hwm5_conf.h>
/* Hardware Monitor */ /* Hardware Monitor */
static u16 hwm_base = 0xa00; static u16 hwm_base = 0xa00;
static void hwm_write(u8 reg, u8 value)
{
outb(reg, hwm_base + 0x05);
outb(value, hwm_base + 0x06);
}
static void hwm_bank(u8 bank)
{
hwm_write(0x4e, bank);
}
#define FAN_CRUISE_CONTROL_DISABLED 0 #define FAN_CRUISE_CONTROL_DISABLED 0
#define FAN_CRUISE_CONTROL_SPEED 1 #define FAN_CRUISE_CONTROL_SPEED 1
#define FAN_CRUISE_CONTROL_THERMAL 2 #define FAN_CRUISE_CONTROL_THERMAL 2
@ -86,16 +76,16 @@ static void hwm_setup(void)
sysfan_speed = FAN_SPEED_5625; sysfan_speed = FAN_SPEED_5625;
get_option(&sysfan_speed, "sysfan_speed"); get_option(&sysfan_speed, "sysfan_speed");
hwm_bank(0); pnp_write_hwm5_index(hwm_base, 0x4e, 0);
hwm_write(0x59, 0x20); /* Diode Selection */ pnp_write_hwm5_index(hwm_base, 0x59, 0x20); /* Diode Selection */
hwm_write(0x5d, 0x0f); /* All Sensors Diode, not Thermistor */ pnp_write_hwm5_index(hwm_base, 0x5d, 0x0f); /* All Sensors Diode, not Thermistor */
hwm_bank(4); pnp_write_hwm5_index(hwm_base, 0x4e, 4);
hwm_write(0x54, 0xf1); /* SYSTIN temperature offset */ pnp_write_hwm5_index(hwm_base, 0x54, 0xf1); /* SYSTIN temperature offset */
hwm_write(0x55, 0x19); /* CPUTIN temperature offset */ pnp_write_hwm5_index(hwm_base, 0x55, 0x19); /* CPUTIN temperature offset */
hwm_write(0x56, 0xfc); /* AUXTIN temperature offset */ pnp_write_hwm5_index(hwm_base, 0x56, 0xfc); /* AUXTIN temperature offset */
hwm_bank(0x80); /* Default */ pnp_write_hwm5_index(hwm_base, 0x4e, 0x80); /* Default */
u8 fan_config = 0; u8 fan_config = 0;
/* 00 FANOUT is Manual Mode */ /* 00 FANOUT is Manual Mode */
@ -110,43 +100,45 @@ static void hwm_setup(void)
case FAN_CRUISE_CONTROL_THERMAL: fan_config |= (1 << 2); break; case FAN_CRUISE_CONTROL_THERMAL: fan_config |= (1 << 2); break;
} }
/* This register must be written first */ /* This register must be written first */
hwm_write(0x04, fan_config); pnp_write_hwm5_index(hwm_base, 0x04, fan_config);
switch (cpufan_control) { switch (cpufan_control) {
case FAN_CRUISE_CONTROL_SPEED: case FAN_CRUISE_CONTROL_SPEED: /* CPUFANIN target speed */
printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to %d RPM\n", printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to %d RPM\n",
fan_speeds[cpufan_speed].fan_speed); fan_speeds[cpufan_speed].fan_speed);
hwm_write(0x06, fan_speeds[cpufan_speed].fan_in); /* CPUFANIN target speed */ pnp_write_hwm5_index(hwm_base, 0x06, fan_speeds[cpufan_speed].fan_in);
break; break;
case FAN_CRUISE_CONTROL_THERMAL: case FAN_CRUISE_CONTROL_THERMAL: /* CPUFANIN target temperature */
printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to activation at %d deg C/%d deg F\n", printk(BIOS_DEBUG, "Fan Cruise Control setting CPU fan to activation at %d deg C/%d deg F\n",
temperatures[cpufan_temperature].deg_celsius, temperatures[cpufan_temperature].deg_celsius,
temperatures[cpufan_temperature].deg_fahrenheit); temperatures[cpufan_temperature].deg_fahrenheit);
hwm_write(0x06, temperatures[cpufan_temperature].deg_celsius); /* CPUFANIN target temperature */ pnp_write_hwm5_index(hwm_base, 0x06,
temperatures[cpufan_temperature].deg_celsius);
break; break;
} }
switch (sysfan_control) { switch (sysfan_control) {
case FAN_CRUISE_CONTROL_SPEED: case FAN_CRUISE_CONTROL_SPEED: /* SYSFANIN target speed */
printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to %d RPM\n", printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to %d RPM\n",
fan_speeds[sysfan_speed].fan_speed); fan_speeds[sysfan_speed].fan_speed);
hwm_write(0x05, fan_speeds[sysfan_speed].fan_in); /* SYSFANIN target speed */ pnp_write_hwm5_index(hwm_base, 0x05, fan_speeds[sysfan_speed].fan_in);
break; break;
case FAN_CRUISE_CONTROL_THERMAL: case FAN_CRUISE_CONTROL_THERMAL: /* SYSFANIN target temperature */
printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to activation at %d deg C/%d deg F\n", printk(BIOS_DEBUG, "Fan Cruise Control setting system fan to activation at %d deg C/%d deg F\n",
temperatures[sysfan_temperature].deg_celsius, temperatures[sysfan_temperature].deg_celsius,
temperatures[sysfan_temperature].deg_fahrenheit); temperatures[sysfan_temperature].deg_fahrenheit);
hwm_write(0x05, temperatures[sysfan_temperature].deg_celsius); /* SYSFANIN target temperature */ pnp_write_hwm5_index(hwm_base, 0x05,
temperatures[sysfan_temperature].deg_celsius);
break; break;
} }
hwm_write(0x0e, 0x02); /* Fan Output Step Down Time */ pnp_write_hwm5_index(hwm_base, 0x0e, 0x02); /* Fan Output Step Down Time */
hwm_write(0x0f, 0x02); /* Fan Output Step Up Time */ pnp_write_hwm5_index(hwm_base, 0x0f, 0x02); /* Fan Output Step Up Time */
hwm_write(0x47, 0xaf); /* FAN divisor register */ pnp_write_hwm5_index(hwm_base, 0x47, 0xaf); /* FAN divisor register */
hwm_write(0x4b, 0x84); /* AUXFANIN speed divisor */ pnp_write_hwm5_index(hwm_base, 0x4b, 0x84); /* AUXFANIN speed divisor */
hwm_write(0x40, 0x01); /* Init, but no SMI# */ pnp_write_hwm5_index(hwm_base, 0x40, 0x01); /* Init, but no SMI# */
} }
/* mainboard_enable is executed as first thing after */ /* mainboard_enable is executed as first thing after */