Loading drivers/spi/spi-mt65xx.c +18 −10 Original line number Original line Diff line number Diff line Loading @@ -323,7 +323,8 @@ static int mtk_spi_fifo_transfer(struct spi_master *master, struct spi_device *spi, struct spi_device *spi, struct spi_transfer *xfer) struct spi_transfer *xfer) { { int cnt; int cnt, remainder; u32 reg_val; struct mtk_spi *mdata = spi_master_get_devdata(master); struct mtk_spi *mdata = spi_master_get_devdata(master); mdata->cur_transfer = xfer; mdata->cur_transfer = xfer; Loading @@ -331,12 +332,16 @@ static int mtk_spi_fifo_transfer(struct spi_master *master, mtk_spi_prepare_transfer(master, xfer); mtk_spi_prepare_transfer(master, xfer); mtk_spi_setup_packet(master); mtk_spi_setup_packet(master); if (xfer->len % 4) cnt = xfer->len / 4 + 1; else cnt = xfer->len / 4; cnt = xfer->len / 4; iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt); iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt); remainder = xfer->len % 4; if (remainder > 0) { reg_val = 0; memcpy(®_val, xfer->tx_buf + (cnt * 4), remainder); writel(reg_val, mdata->base + SPI_TX_DATA_REG); } mtk_spi_enable_transfer(master); mtk_spi_enable_transfer(master); return 1; return 1; Loading Loading @@ -418,7 +423,7 @@ static int mtk_spi_setup(struct spi_device *spi) static irqreturn_t mtk_spi_interrupt(int irq, void *dev_id) static irqreturn_t mtk_spi_interrupt(int irq, void *dev_id) { { u32 cmd, reg_val, cnt; u32 cmd, reg_val, cnt, remainder; struct spi_master *master = dev_id; struct spi_master *master = dev_id; struct mtk_spi *mdata = spi_master_get_devdata(master); struct mtk_spi *mdata = spi_master_get_devdata(master); struct spi_transfer *trans = mdata->cur_transfer; struct spi_transfer *trans = mdata->cur_transfer; Loading @@ -431,12 +436,15 @@ static irqreturn_t mtk_spi_interrupt(int irq, void *dev_id) if (!master->can_dma(master, master->cur_msg->spi, trans)) { if (!master->can_dma(master, master->cur_msg->spi, trans)) { if (trans->rx_buf) { if (trans->rx_buf) { if (mdata->xfer_len % 4) cnt = mdata->xfer_len / 4 + 1; else cnt = mdata->xfer_len / 4; cnt = mdata->xfer_len / 4; ioread32_rep(mdata->base + SPI_RX_DATA_REG, ioread32_rep(mdata->base + SPI_RX_DATA_REG, trans->rx_buf, cnt); trans->rx_buf, cnt); remainder = mdata->xfer_len % 4; if (remainder > 0) { reg_val = readl(mdata->base + SPI_RX_DATA_REG); memcpy(trans->rx_buf + (cnt * 4), ®_val, remainder); } } } spi_finalize_current_transfer(master); spi_finalize_current_transfer(master); return IRQ_HANDLED; return IRQ_HANDLED; Loading Loading
drivers/spi/spi-mt65xx.c +18 −10 Original line number Original line Diff line number Diff line Loading @@ -323,7 +323,8 @@ static int mtk_spi_fifo_transfer(struct spi_master *master, struct spi_device *spi, struct spi_device *spi, struct spi_transfer *xfer) struct spi_transfer *xfer) { { int cnt; int cnt, remainder; u32 reg_val; struct mtk_spi *mdata = spi_master_get_devdata(master); struct mtk_spi *mdata = spi_master_get_devdata(master); mdata->cur_transfer = xfer; mdata->cur_transfer = xfer; Loading @@ -331,12 +332,16 @@ static int mtk_spi_fifo_transfer(struct spi_master *master, mtk_spi_prepare_transfer(master, xfer); mtk_spi_prepare_transfer(master, xfer); mtk_spi_setup_packet(master); mtk_spi_setup_packet(master); if (xfer->len % 4) cnt = xfer->len / 4 + 1; else cnt = xfer->len / 4; cnt = xfer->len / 4; iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt); iowrite32_rep(mdata->base + SPI_TX_DATA_REG, xfer->tx_buf, cnt); remainder = xfer->len % 4; if (remainder > 0) { reg_val = 0; memcpy(®_val, xfer->tx_buf + (cnt * 4), remainder); writel(reg_val, mdata->base + SPI_TX_DATA_REG); } mtk_spi_enable_transfer(master); mtk_spi_enable_transfer(master); return 1; return 1; Loading Loading @@ -418,7 +423,7 @@ static int mtk_spi_setup(struct spi_device *spi) static irqreturn_t mtk_spi_interrupt(int irq, void *dev_id) static irqreturn_t mtk_spi_interrupt(int irq, void *dev_id) { { u32 cmd, reg_val, cnt; u32 cmd, reg_val, cnt, remainder; struct spi_master *master = dev_id; struct spi_master *master = dev_id; struct mtk_spi *mdata = spi_master_get_devdata(master); struct mtk_spi *mdata = spi_master_get_devdata(master); struct spi_transfer *trans = mdata->cur_transfer; struct spi_transfer *trans = mdata->cur_transfer; Loading @@ -431,12 +436,15 @@ static irqreturn_t mtk_spi_interrupt(int irq, void *dev_id) if (!master->can_dma(master, master->cur_msg->spi, trans)) { if (!master->can_dma(master, master->cur_msg->spi, trans)) { if (trans->rx_buf) { if (trans->rx_buf) { if (mdata->xfer_len % 4) cnt = mdata->xfer_len / 4 + 1; else cnt = mdata->xfer_len / 4; cnt = mdata->xfer_len / 4; ioread32_rep(mdata->base + SPI_RX_DATA_REG, ioread32_rep(mdata->base + SPI_RX_DATA_REG, trans->rx_buf, cnt); trans->rx_buf, cnt); remainder = mdata->xfer_len % 4; if (remainder > 0) { reg_val = readl(mdata->base + SPI_RX_DATA_REG); memcpy(trans->rx_buf + (cnt * 4), ®_val, remainder); } } } spi_finalize_current_transfer(master); spi_finalize_current_transfer(master); return IRQ_HANDLED; return IRQ_HANDLED; Loading