Message ID | 20221115124655.10124-1-bayi.cheng@mediatek.com |
---|---|
State | Accepted |
Commit | 63d9a4d88499569210c445a862209515207c2732 |
Headers | show |
Series | [v1] spi: spi-mtk-nor: Unify write buffer on/off | expand |
On Tue, 2022-11-15 at 20:46 +0800, Bayi Cheng wrote: > From: bayi cheng <bayi.cheng@mediatek.com> > > The logical structures of mtk_nor_write_buffer_enable and > mtk_nor_write_buffer_disable are very similar, So it is necessary to > combine them into one. > > Signed-off-by: bayi cheng <bayi.cheng@mediatek.com> > --- > Change in v1: > -Delete mtk_nor_write_buffer_enable. > -Delete mtk_nor_write_buffer_disable. > -Add mtk_nor_setup_write_buffer. > --- > --- > drivers/spi/spi-mtk-nor.c | 40 ++++++++++++++++--------------------- > -- > 1 file changed, 16 insertions(+), 24 deletions(-) > > diff --git a/drivers/spi/spi-mtk-nor.c b/drivers/spi/spi-mtk-nor.c > index d167699a1a96..e8b355f5be56 100644 > --- a/drivers/spi/spi-mtk-nor.c > +++ b/drivers/spi/spi-mtk-nor.c > @@ -443,36 +443,28 @@ static int mtk_nor_read_pio(struct mtk_nor *sp, > const struct spi_mem_op *op) > return ret; > } > > -static int mtk_nor_write_buffer_enable(struct mtk_nor *sp) > +static int mtk_nor_setup_write_buffer(struct mtk_nor *sp, bool on) > { > int ret; > u32 val; > > - if (sp->wbuf_en) > + if (!(sp->wbuf_en ^ on)) > return 0; > > val = readl(sp->base + MTK_NOR_REG_CFG2); > - writel(val | MTK_NOR_WR_BUF_EN, sp->base + MTK_NOR_REG_CFG2); > - ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, val, > - val & MTK_NOR_WR_BUF_EN, 0, 10000); > - if (!ret) > - sp->wbuf_en = true; > - return ret; > -} > - > -static int mtk_nor_write_buffer_disable(struct mtk_nor *sp) > -{ > - int ret; > - u32 val; > + if (on) { > + writel(val | MTK_NOR_WR_BUF_EN, sp->base + > MTK_NOR_REG_CFG2); > + ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, > val, > + val & MTK_NOR_WR_BUF_EN, 0, > 10000); > + } else { > + writel(val & ~MTK_NOR_WR_BUF_EN, sp->base + > MTK_NOR_REG_CFG2); > + ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, > val, > + !(val & MTK_NOR_WR_BUF_EN), 0, > 10000); > + } > > - if (!sp->wbuf_en) > - return 0; > - val = readl(sp->base + MTK_NOR_REG_CFG2); > - writel(val & ~MTK_NOR_WR_BUF_EN, sp->base + MTK_NOR_REG_CFG2); > - ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, val, > - !(val & MTK_NOR_WR_BUF_EN), 0, 10000); > if (!ret) > - sp->wbuf_en = false; > + sp->wbuf_en = on; > + > return ret; > } > > @@ -482,7 +474,7 @@ static int mtk_nor_pp_buffered(struct mtk_nor > *sp, const struct spi_mem_op *op) > u32 val; > int ret, i; > > - ret = mtk_nor_write_buffer_enable(sp); > + ret = mtk_nor_setup_write_buffer(sp, true); > if (ret < 0) > return ret; > > @@ -501,7 +493,7 @@ static int mtk_nor_pp_unbuffered(struct mtk_nor > *sp, > const u8 *buf = op->data.buf.out; > int ret; > > - ret = mtk_nor_write_buffer_disable(sp); > + ret = mtk_nor_setup_write_buffer(sp, false); > if (ret < 0) > return ret; > writeb(buf[0], sp->base + MTK_NOR_REG_WDATA); > @@ -608,7 +600,7 @@ static int mtk_nor_exec_op(struct spi_mem *mem, > const struct spi_mem_op *op) > } > > if ((op->data.dir == SPI_MEM_DATA_IN) && > mtk_nor_match_read(op)) { > - ret = mtk_nor_write_buffer_disable(sp); > + ret = mtk_nor_setup_write_buffer(sp, false); > if (ret < 0) > return ret; > mtk_nor_setup_bus(sp, op); Hi Angelo, Hi David, Hi Matthias, Just a gentle ping on this. Could you please review this patch and give us some suggestion? Thanks, Bayi
On Tue, 15 Nov 2022 20:46:55 +0800, Bayi Cheng wrote: > From: bayi cheng <bayi.cheng@mediatek.com> > > The logical structures of mtk_nor_write_buffer_enable and > mtk_nor_write_buffer_disable are very similar, So it is necessary to > combine them into one. > > > [...] Applied to https://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi.git for-next Thanks! [1/1] spi: spi-mtk-nor: Unify write buffer on/off commit: 63d9a4d88499569210c445a862209515207c2732 All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark
diff --git a/drivers/spi/spi-mtk-nor.c b/drivers/spi/spi-mtk-nor.c index d167699a1a96..e8b355f5be56 100644 --- a/drivers/spi/spi-mtk-nor.c +++ b/drivers/spi/spi-mtk-nor.c @@ -443,36 +443,28 @@ static int mtk_nor_read_pio(struct mtk_nor *sp, const struct spi_mem_op *op) return ret; } -static int mtk_nor_write_buffer_enable(struct mtk_nor *sp) +static int mtk_nor_setup_write_buffer(struct mtk_nor *sp, bool on) { int ret; u32 val; - if (sp->wbuf_en) + if (!(sp->wbuf_en ^ on)) return 0; val = readl(sp->base + MTK_NOR_REG_CFG2); - writel(val | MTK_NOR_WR_BUF_EN, sp->base + MTK_NOR_REG_CFG2); - ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, val, - val & MTK_NOR_WR_BUF_EN, 0, 10000); - if (!ret) - sp->wbuf_en = true; - return ret; -} - -static int mtk_nor_write_buffer_disable(struct mtk_nor *sp) -{ - int ret; - u32 val; + if (on) { + writel(val | MTK_NOR_WR_BUF_EN, sp->base + MTK_NOR_REG_CFG2); + ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, val, + val & MTK_NOR_WR_BUF_EN, 0, 10000); + } else { + writel(val & ~MTK_NOR_WR_BUF_EN, sp->base + MTK_NOR_REG_CFG2); + ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, val, + !(val & MTK_NOR_WR_BUF_EN), 0, 10000); + } - if (!sp->wbuf_en) - return 0; - val = readl(sp->base + MTK_NOR_REG_CFG2); - writel(val & ~MTK_NOR_WR_BUF_EN, sp->base + MTK_NOR_REG_CFG2); - ret = readl_poll_timeout(sp->base + MTK_NOR_REG_CFG2, val, - !(val & MTK_NOR_WR_BUF_EN), 0, 10000); if (!ret) - sp->wbuf_en = false; + sp->wbuf_en = on; + return ret; } @@ -482,7 +474,7 @@ static int mtk_nor_pp_buffered(struct mtk_nor *sp, const struct spi_mem_op *op) u32 val; int ret, i; - ret = mtk_nor_write_buffer_enable(sp); + ret = mtk_nor_setup_write_buffer(sp, true); if (ret < 0) return ret; @@ -501,7 +493,7 @@ static int mtk_nor_pp_unbuffered(struct mtk_nor *sp, const u8 *buf = op->data.buf.out; int ret; - ret = mtk_nor_write_buffer_disable(sp); + ret = mtk_nor_setup_write_buffer(sp, false); if (ret < 0) return ret; writeb(buf[0], sp->base + MTK_NOR_REG_WDATA); @@ -608,7 +600,7 @@ static int mtk_nor_exec_op(struct spi_mem *mem, const struct spi_mem_op *op) } if ((op->data.dir == SPI_MEM_DATA_IN) && mtk_nor_match_read(op)) { - ret = mtk_nor_write_buffer_disable(sp); + ret = mtk_nor_setup_write_buffer(sp, false); if (ret < 0) return ret; mtk_nor_setup_bus(sp, op);