[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20260113133831.3422480-3-s9430939@naver.com>
Date: Tue, 13 Jan 2026 22:38:31 +0900
From: Minu Jin <s9430939@...er.com>
To: gregkh@...uxfoundation.org
Cc: ovidiu.panait.oss@...il.com,
gshahrouzi@...il.com,
linux-staging@...ts.linux.dev,
linux-kernel@...r.kernel.org,
Minu Jin <s9430939@...er.com>
Subject: [PATCH 2/2] staging: axis-fifo: Use bulk I/O accessors for data transfers
Replace manual for loops with ioread32_rep/iowrite32_rep.
Add axis_fifo_read_data() and axis_fifo_write_data() wrappers to
encapsulate these block-transfer operations.
No functional changes intended
Signed-off-by: Minu Jin <s9430939@...er.com>
---
drivers/staging/axis-fifo/axis-fifo.c | 19 +++++++++++++------
1 file changed, 13 insertions(+), 6 deletions(-)
diff --git a/drivers/staging/axis-fifo/axis-fifo.c b/drivers/staging/axis-fifo/axis-fifo.c
index 525156583c4a..9663d2efd411 100644
--- a/drivers/staging/axis-fifo/axis-fifo.c
+++ b/drivers/staging/axis-fifo/axis-fifo.c
@@ -150,11 +150,21 @@ static inline u32 axis_fifo_read_reg(struct axis_fifo *fifo, int offset)
return ioread32(fifo->base_addr + offset);
}
+static inline void axis_fifo_read_data(struct axis_fifo *fifo, void *buf, int count)
+{
+ ioread32_rep(fifo->base_addr + XLLF_RDFD_OFFSET, buf, count);
+}
+
static inline void axis_fifo_write_reg(struct axis_fifo *fifo, int offset, u32 val)
{
iowrite32(val, fifo->base_addr + offset);
}
+static inline void axis_fifo_write_data(struct axis_fifo *fifo, const void *buf, int count)
+{
+ iowrite32_rep(fifo->base_addr + XLLF_TDFD_OFFSET, buf, count);
+}
+
static void reset_ip_core(struct axis_fifo *fifo)
{
axis_fifo_write_reg(fifo, XLLF_SRR_OFFSET, XLLF_SRR_RESET_MASK);
@@ -259,10 +269,8 @@ static ssize_t axis_fifo_read(struct file *f, char __user *buf,
while (words_available > 0) {
copy = min(words_available, READ_BUF_SIZE);
- for (i = 0; i < copy; i++) {
- tmp_buf[i] = ioread32(fifo->base_addr +
- XLLF_RDFD_OFFSET);
- }
+ axis_fifo_read_data(fifo, tmp_buf, copy);
+
words_available -= copy;
if (copy_to_user(buf + copied * sizeof(u32), tmp_buf,
@@ -378,8 +386,7 @@ static ssize_t axis_fifo_write(struct file *f, const char __user *buf,
goto end_unlock;
}
- for (int i = 0; i < words_to_write; ++i)
- iowrite32(txbuf[i], fifo->base_addr + XLLF_TDFD_OFFSET);
+ axis_fifo_write_data(fifo, txbuf, words_to_write);
/* write packet size to fifo */
axis_fifo_write_reg(fifo, XLLF_TLR_OFFSET, len);
--
2.43.0
Powered by blists - more mailing lists