diff options
| -rw-r--r-- | drivers/ide/ide-dma.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/drivers/ide/ide-dma.c b/drivers/ide/ide-dma.c index 85db8e85443a..e8c6e1ed497a 100644 --- a/drivers/ide/ide-dma.c +++ b/drivers/ide/ide-dma.c | |||
| @@ -702,8 +702,22 @@ static unsigned int ide_get_mode_mask(ide_drive_t *drive, u8 base) | |||
| 702 | mask = id->dma_mword & hwif->mwdma_mask; | 702 | mask = id->dma_mword & hwif->mwdma_mask; |
| 703 | break; | 703 | break; |
| 704 | case XFER_SW_DMA_0: | 704 | case XFER_SW_DMA_0: |
| 705 | if (id->field_valid & 2) | 705 | if (id->field_valid & 2) { |
| 706 | mask = id->dma_1word & hwif->swdma_mask; | 706 | mask = id->dma_1word & hwif->swdma_mask; |
| 707 | } else if (id->tDMA) { | ||
| 708 | /* | ||
| 709 | * ide_fix_driveid() doesn't convert ->tDMA to the | ||
| 710 | * CPU endianness so we need to do it here | ||
| 711 | */ | ||
| 712 | u8 mode = le16_to_cpu(id->tDMA); | ||
| 713 | |||
| 714 | /* | ||
| 715 | * if the mode is valid convert it to the mask | ||
| 716 | * (the maximum allowed mode is XFER_SW_DMA_2) | ||
| 717 | */ | ||
| 718 | if (mode <= 2) | ||
| 719 | mask = ((2 << mode) - 1) & hwif->swdma_mask; | ||
| 720 | } | ||
| 707 | break; | 721 | break; |
| 708 | default: | 722 | default: |
| 709 | BUG(); | 723 | BUG(); |
