mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-11 15:49:56 +00:00
ide: fix IDE ACPI for slave device-only configurations
ACPI _GTM / _PS0 / _STM were not called if only slave device was present. Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
This commit is contained in:
parent
0964dbe60c
commit
1ea1031cf9
@ -365,15 +365,15 @@ __IDE_DEVSET(pio_mode, 0, NULL, set_pio_mode);
|
|||||||
|
|
||||||
static int generic_ide_suspend(struct device *dev, pm_message_t mesg)
|
static int generic_ide_suspend(struct device *dev, pm_message_t mesg)
|
||||||
{
|
{
|
||||||
ide_drive_t *drive = dev->driver_data;
|
ide_drive_t *drive = dev->driver_data, *pair = ide_get_pair_dev(drive);
|
||||||
ide_hwif_t *hwif = HWIF(drive);
|
ide_hwif_t *hwif = HWIF(drive);
|
||||||
struct request *rq;
|
struct request *rq;
|
||||||
struct request_pm_state rqpm;
|
struct request_pm_state rqpm;
|
||||||
ide_task_t args;
|
ide_task_t args;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* Call ACPI _GTM only once */
|
/* call ACPI _GTM only once */
|
||||||
if (!(drive->dn % 2))
|
if ((drive->dn & 1) == 0 || pair == NULL)
|
||||||
ide_acpi_get_timing(hwif);
|
ide_acpi_get_timing(hwif);
|
||||||
|
|
||||||
memset(&rqpm, 0, sizeof(rqpm));
|
memset(&rqpm, 0, sizeof(rqpm));
|
||||||
@ -389,26 +389,25 @@ static int generic_ide_suspend(struct device *dev, pm_message_t mesg)
|
|||||||
|
|
||||||
ret = blk_execute_rq(drive->queue, NULL, rq, 0);
|
ret = blk_execute_rq(drive->queue, NULL, rq, 0);
|
||||||
blk_put_request(rq);
|
blk_put_request(rq);
|
||||||
/* only call ACPI _PS3 after both drivers are suspended */
|
|
||||||
if (!ret && (((drive->dn % 2) && hwif->drives[0].present
|
/* call ACPI _PS3 only after both devices are suspended */
|
||||||
&& hwif->drives[1].present)
|
if (ret == 0 && ((drive->dn & 1) || pair == NULL))
|
||||||
|| !hwif->drives[0].present
|
|
||||||
|| !hwif->drives[1].present))
|
|
||||||
ide_acpi_set_state(hwif, 0);
|
ide_acpi_set_state(hwif, 0);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int generic_ide_resume(struct device *dev)
|
static int generic_ide_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
ide_drive_t *drive = dev->driver_data;
|
ide_drive_t *drive = dev->driver_data, *pair = ide_get_pair_dev(drive);
|
||||||
ide_hwif_t *hwif = HWIF(drive);
|
ide_hwif_t *hwif = HWIF(drive);
|
||||||
struct request *rq;
|
struct request *rq;
|
||||||
struct request_pm_state rqpm;
|
struct request_pm_state rqpm;
|
||||||
ide_task_t args;
|
ide_task_t args;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
/* Call ACPI _STM only once */
|
/* call ACPI _PS0 / _STM only once */
|
||||||
if (!(drive->dn % 2)) {
|
if ((drive->dn & 1) == 0 || pair == NULL) {
|
||||||
ide_acpi_set_state(hwif, 1);
|
ide_acpi_set_state(hwif, 1);
|
||||||
ide_acpi_push_timing(hwif);
|
ide_acpi_push_timing(hwif);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user