|
@@ -569,9 +569,10 @@ static void atmci_dma_cleanup(struct atmel_mci *host)
|
|
{
|
|
{
|
|
struct mmc_data *data = host->data;
|
|
struct mmc_data *data = host->data;
|
|
|
|
|
|
- dma_unmap_sg(&host->pdev->dev, data->sg, data->sg_len,
|
|
|
|
- ((data->flags & MMC_DATA_WRITE)
|
|
|
|
- ? DMA_TO_DEVICE : DMA_FROM_DEVICE));
|
|
|
|
|
|
+ if (data)
|
|
|
|
+ dma_unmap_sg(&host->pdev->dev, data->sg, data->sg_len,
|
|
|
|
+ ((data->flags & MMC_DATA_WRITE)
|
|
|
|
+ ? DMA_TO_DEVICE : DMA_FROM_DEVICE));
|
|
}
|
|
}
|
|
|
|
|
|
static void atmci_stop_dma(struct atmel_mci *host)
|
|
static void atmci_stop_dma(struct atmel_mci *host)
|
|
@@ -1099,8 +1100,8 @@ static void atmci_command_complete(struct atmel_mci *host,
|
|
"command error: status=0x%08x\n", status);
|
|
"command error: status=0x%08x\n", status);
|
|
|
|
|
|
if (cmd->data) {
|
|
if (cmd->data) {
|
|
- host->data = NULL;
|
|
|
|
atmci_stop_dma(host);
|
|
atmci_stop_dma(host);
|
|
|
|
+ host->data = NULL;
|
|
mci_writel(host, IDR, MCI_NOTBUSY
|
|
mci_writel(host, IDR, MCI_NOTBUSY
|
|
| MCI_TXRDY | MCI_RXRDY
|
|
| MCI_TXRDY | MCI_RXRDY
|
|
| ATMCI_DATA_ERROR_FLAGS);
|
|
| ATMCI_DATA_ERROR_FLAGS);
|