mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-07 21:24:00 +08:00
spi: fsl-cpm: Properly define and use IO pointers
Sparse reports several issues with IO pointers. Fix it by adding missing __iomem flags and using iowriteXXbe() generic helpers instead of the powerpc specific out_beXX() ones. Reported-by: kernel test robot <lkp@intel.com> Closes: https://lore.kernel.org/oe-kbuild-all/202307252052.7RqHxFZj-lkp@intel.com/ Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu> Link: https://lore.kernel.org/r/18a65dca9134f6fc35932408066d4a8284cbfa65.1691571190.git.christophe.leroy@csgroup.eu Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
2ca03ecc9c
commit
ddaec4e44d
@ -56,12 +56,12 @@ void fsl_spi_cpm_reinit_txrx(struct mpc8xxx_spi *mspi)
|
|||||||
QE_CR_PROTOCOL_UNSPECIFIED, 0);
|
QE_CR_PROTOCOL_UNSPECIFIED, 0);
|
||||||
} else {
|
} else {
|
||||||
if (mspi->flags & SPI_CPM1) {
|
if (mspi->flags & SPI_CPM1) {
|
||||||
out_be32(&mspi->pram->rstate, 0);
|
iowrite32be(0, &mspi->pram->rstate);
|
||||||
out_be16(&mspi->pram->rbptr,
|
iowrite16be(ioread16be(&mspi->pram->rbase),
|
||||||
in_be16(&mspi->pram->rbase));
|
&mspi->pram->rbptr);
|
||||||
out_be32(&mspi->pram->tstate, 0);
|
iowrite32be(0, &mspi->pram->tstate);
|
||||||
out_be16(&mspi->pram->tbptr,
|
iowrite16be(ioread16be(&mspi->pram->tbase),
|
||||||
in_be16(&mspi->pram->tbase));
|
&mspi->pram->tbptr);
|
||||||
} else {
|
} else {
|
||||||
cpm_command(CPM_SPI_CMD, CPM_CR_INIT_TRX);
|
cpm_command(CPM_SPI_CMD, CPM_CR_INIT_TRX);
|
||||||
}
|
}
|
||||||
@ -75,24 +75,24 @@ static void fsl_spi_cpm_bufs_start(struct mpc8xxx_spi *mspi)
|
|||||||
struct cpm_buf_desc __iomem *rx_bd = mspi->rx_bd;
|
struct cpm_buf_desc __iomem *rx_bd = mspi->rx_bd;
|
||||||
unsigned int xfer_len = min(mspi->count, SPI_MRBLR);
|
unsigned int xfer_len = min(mspi->count, SPI_MRBLR);
|
||||||
unsigned int xfer_ofs;
|
unsigned int xfer_ofs;
|
||||||
struct fsl_spi_reg *reg_base = mspi->reg_base;
|
struct fsl_spi_reg __iomem *reg_base = mspi->reg_base;
|
||||||
|
|
||||||
xfer_ofs = mspi->xfer_in_progress->len - mspi->count;
|
xfer_ofs = mspi->xfer_in_progress->len - mspi->count;
|
||||||
|
|
||||||
if (mspi->rx_dma == mspi->dma_dummy_rx)
|
if (mspi->rx_dma == mspi->dma_dummy_rx)
|
||||||
out_be32(&rx_bd->cbd_bufaddr, mspi->rx_dma);
|
iowrite32be(mspi->rx_dma, &rx_bd->cbd_bufaddr);
|
||||||
else
|
else
|
||||||
out_be32(&rx_bd->cbd_bufaddr, mspi->rx_dma + xfer_ofs);
|
iowrite32be(mspi->rx_dma + xfer_ofs, &rx_bd->cbd_bufaddr);
|
||||||
out_be16(&rx_bd->cbd_datlen, 0);
|
iowrite16be(0, &rx_bd->cbd_datlen);
|
||||||
out_be16(&rx_bd->cbd_sc, BD_SC_EMPTY | BD_SC_INTRPT | BD_SC_WRAP);
|
iowrite16be(BD_SC_EMPTY | BD_SC_INTRPT | BD_SC_WRAP, &rx_bd->cbd_sc);
|
||||||
|
|
||||||
if (mspi->tx_dma == mspi->dma_dummy_tx)
|
if (mspi->tx_dma == mspi->dma_dummy_tx)
|
||||||
out_be32(&tx_bd->cbd_bufaddr, mspi->tx_dma);
|
iowrite32be(mspi->tx_dma, &tx_bd->cbd_bufaddr);
|
||||||
else
|
else
|
||||||
out_be32(&tx_bd->cbd_bufaddr, mspi->tx_dma + xfer_ofs);
|
iowrite32be(mspi->tx_dma + xfer_ofs, &tx_bd->cbd_bufaddr);
|
||||||
out_be16(&tx_bd->cbd_datlen, xfer_len);
|
iowrite16be(xfer_len, &tx_bd->cbd_datlen);
|
||||||
out_be16(&tx_bd->cbd_sc, BD_SC_READY | BD_SC_INTRPT | BD_SC_WRAP |
|
iowrite16be(BD_SC_READY | BD_SC_INTRPT | BD_SC_WRAP | BD_SC_LAST,
|
||||||
BD_SC_LAST);
|
&tx_bd->cbd_sc);
|
||||||
|
|
||||||
/* start transfer */
|
/* start transfer */
|
||||||
mpc8xxx_spi_write_reg(®_base->command, SPCOM_STR);
|
mpc8xxx_spi_write_reg(®_base->command, SPCOM_STR);
|
||||||
@ -102,7 +102,7 @@ int fsl_spi_cpm_bufs(struct mpc8xxx_spi *mspi,
|
|||||||
struct spi_transfer *t, bool is_dma_mapped)
|
struct spi_transfer *t, bool is_dma_mapped)
|
||||||
{
|
{
|
||||||
struct device *dev = mspi->dev;
|
struct device *dev = mspi->dev;
|
||||||
struct fsl_spi_reg *reg_base = mspi->reg_base;
|
struct fsl_spi_reg __iomem *reg_base = mspi->reg_base;
|
||||||
|
|
||||||
if (is_dma_mapped) {
|
if (is_dma_mapped) {
|
||||||
mspi->map_tx_dma = 0;
|
mspi->map_tx_dma = 0;
|
||||||
@ -123,7 +123,7 @@ int fsl_spi_cpm_bufs(struct mpc8xxx_spi *mspi,
|
|||||||
}
|
}
|
||||||
if (t->bits_per_word == 16 && t->tx_buf) {
|
if (t->bits_per_word == 16 && t->tx_buf) {
|
||||||
const u16 *src = t->tx_buf;
|
const u16 *src = t->tx_buf;
|
||||||
u16 *dst;
|
__le16 *dst;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
dst = kmalloc(t->len, GFP_KERNEL);
|
dst = kmalloc(t->len, GFP_KERNEL);
|
||||||
@ -202,12 +202,12 @@ EXPORT_SYMBOL_GPL(fsl_spi_cpm_bufs_complete);
|
|||||||
void fsl_spi_cpm_irq(struct mpc8xxx_spi *mspi, u32 events)
|
void fsl_spi_cpm_irq(struct mpc8xxx_spi *mspi, u32 events)
|
||||||
{
|
{
|
||||||
u16 len;
|
u16 len;
|
||||||
struct fsl_spi_reg *reg_base = mspi->reg_base;
|
struct fsl_spi_reg __iomem *reg_base = mspi->reg_base;
|
||||||
|
|
||||||
dev_dbg(mspi->dev, "%s: bd datlen %d, count %d\n", __func__,
|
dev_dbg(mspi->dev, "%s: bd datlen %d, count %d\n", __func__,
|
||||||
in_be16(&mspi->rx_bd->cbd_datlen), mspi->count);
|
ioread16be(&mspi->rx_bd->cbd_datlen), mspi->count);
|
||||||
|
|
||||||
len = in_be16(&mspi->rx_bd->cbd_datlen);
|
len = ioread16be(&mspi->rx_bd->cbd_datlen);
|
||||||
if (len > mspi->count) {
|
if (len > mspi->count) {
|
||||||
WARN_ON(1);
|
WARN_ON(1);
|
||||||
len = mspi->count;
|
len = mspi->count;
|
||||||
@ -328,7 +328,7 @@ int fsl_spi_cpm_init(struct mpc8xxx_spi *mspi)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (mspi->flags & SPI_CPM1) {
|
if (mspi->flags & SPI_CPM1) {
|
||||||
void *pram;
|
void __iomem *pram;
|
||||||
|
|
||||||
pram = devm_platform_ioremap_resource(to_platform_device(dev),
|
pram = devm_platform_ioremap_resource(to_platform_device(dev),
|
||||||
1);
|
1);
|
||||||
@ -374,21 +374,21 @@ int fsl_spi_cpm_init(struct mpc8xxx_spi *mspi)
|
|||||||
mspi->rx_bd = cpm_muram_addr(bds_ofs + sizeof(*mspi->tx_bd));
|
mspi->rx_bd = cpm_muram_addr(bds_ofs + sizeof(*mspi->tx_bd));
|
||||||
|
|
||||||
/* Initialize parameter ram. */
|
/* Initialize parameter ram. */
|
||||||
out_be16(&mspi->pram->tbase, cpm_muram_offset(mspi->tx_bd));
|
iowrite16be(cpm_muram_offset(mspi->tx_bd), &mspi->pram->tbase);
|
||||||
out_be16(&mspi->pram->rbase, cpm_muram_offset(mspi->rx_bd));
|
iowrite16be(cpm_muram_offset(mspi->rx_bd), &mspi->pram->rbase);
|
||||||
out_8(&mspi->pram->tfcr, CPMFCR_EB | CPMFCR_GBL);
|
iowrite8(CPMFCR_EB | CPMFCR_GBL, &mspi->pram->tfcr);
|
||||||
out_8(&mspi->pram->rfcr, CPMFCR_EB | CPMFCR_GBL);
|
iowrite8(CPMFCR_EB | CPMFCR_GBL, &mspi->pram->rfcr);
|
||||||
out_be16(&mspi->pram->mrblr, SPI_MRBLR);
|
iowrite16be(SPI_MRBLR, &mspi->pram->mrblr);
|
||||||
out_be32(&mspi->pram->rstate, 0);
|
iowrite32be(0, &mspi->pram->rstate);
|
||||||
out_be32(&mspi->pram->rdp, 0);
|
iowrite32be(0, &mspi->pram->rdp);
|
||||||
out_be16(&mspi->pram->rbptr, 0);
|
iowrite16be(0, &mspi->pram->rbptr);
|
||||||
out_be16(&mspi->pram->rbc, 0);
|
iowrite16be(0, &mspi->pram->rbc);
|
||||||
out_be32(&mspi->pram->rxtmp, 0);
|
iowrite32be(0, &mspi->pram->rxtmp);
|
||||||
out_be32(&mspi->pram->tstate, 0);
|
iowrite32be(0, &mspi->pram->tstate);
|
||||||
out_be32(&mspi->pram->tdp, 0);
|
iowrite32be(0, &mspi->pram->tdp);
|
||||||
out_be16(&mspi->pram->tbptr, 0);
|
iowrite16be(0, &mspi->pram->tbptr);
|
||||||
out_be16(&mspi->pram->tbc, 0);
|
iowrite16be(0, &mspi->pram->tbc);
|
||||||
out_be32(&mspi->pram->txtmp, 0);
|
iowrite32be(0, &mspi->pram->txtmp);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user