Commit c52f0aa5 authored by Henrique de Moraes Holschuh's avatar Henrique de Moraes Holschuh Committed by Len Brown

ACPI: ibm-acpi: break fan_read into separate functions

This patch breaks fan_read mechanics into a generic function to get fan
status and speed, and leaves only the procfs interface code in fan_read.
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
parent 3ef8a609
...@@ -1738,36 +1738,90 @@ static int fan_init(void) ...@@ -1738,36 +1738,90 @@ static int fan_init(void)
return 0; return 0;
} }
static int fan_read(char *p) static int fan_get_status(u8 *status)
{ {
int len = 0; u8 s;
u8 lo, hi, status;
switch (fan_status_access_mode) { switch (fan_status_access_mode) {
case IBMACPI_FAN_RD_ACPI_GFAN: case IBMACPI_FAN_RD_ACPI_GFAN:
/* 570, 600e/x, 770e, 770x */ /* 570, 600e/x, 770e, 770x */
if (unlikely(!acpi_evalf(gfan_handle, &status, NULL, "d")))
if (unlikely(!acpi_evalf(gfan_handle, &s, NULL, "d")))
return -EIO; return -EIO;
len += sprintf(p + len, "level:\t\t%d\n", status); if (likely(status))
*status = s & 0x07;
break; break;
case IBMACPI_FAN_RD_TPEC: case IBMACPI_FAN_RD_TPEC:
/* all except 570, 600e/x, 770e, 770x */ /* all except 570, 600e/x, 770e, 770x */
if (unlikely(!acpi_ec_read(fan_status_offset, &status))) if (unlikely(!acpi_ec_read(fan_status_offset, &s)))
return -EIO; return -EIO;
else
len += sprintf(p + len, "status:\t\t%s\n",
enabled(status, 7));
if (likely(status))
*status = s;
break;
default:
return -ENXIO;
}
return 0;
}
static int fan_get_speed(unsigned int *speed)
{
u8 hi, lo;
switch (fan_status_access_mode) {
case IBMACPI_FAN_RD_TPEC:
/* all except 570, 600e/x, 770e, 770x */
if (unlikely(!acpi_ec_read(fan_rpm_offset, &lo) || if (unlikely(!acpi_ec_read(fan_rpm_offset, &lo) ||
!acpi_ec_read(fan_rpm_offset + 1, &hi))) !acpi_ec_read(fan_rpm_offset + 1, &hi)))
return -EIO; return -EIO;
else
len += sprintf(p + len, "speed:\t\t%d\n",
(hi << 8) + lo);
if (likely(speed))
*speed = (hi << 8) | lo;
break;
default:
return -ENXIO;
}
return 0;
}
static int fan_read(char *p)
{
int len = 0;
int rc;
u8 status;
unsigned int speed = 0;
switch (fan_status_access_mode) {
case IBMACPI_FAN_RD_ACPI_GFAN:
/* 570, 600e/x, 770e, 770x */
if ((rc = fan_get_status(&status)) < 0)
return rc;
len += sprintf(p + len, "level:\t\t%d\n", status);
break;
case IBMACPI_FAN_RD_TPEC:
/* all except 570, 600e/x, 770e, 770x */
if ((rc = fan_get_status(&status)) < 0)
return rc;
len += sprintf(p + len, "status:\t\t%s\n", enabled(status, 7));
if ((rc = fan_get_speed(&speed)) < 0)
return rc;
len += sprintf(p + len, "speed:\t\t%d\n", speed);
break; break;
case IBMACPI_FAN_NONE: case IBMACPI_FAN_NONE:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment