Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 81aafb3e authored by Thomas Petazzoni's avatar Thomas Petazzoni Committed by Vinod Koul
Browse files

dmaengine: mv_xor: de-duplicate mv_chan_set_mode*()



When commit 6f166312 ("dmaengine: mv_xor: add support for a38x
command in descriptor mode") added support for the descriptor mode
available in Marvell Armada 38x and later SoCs, it added a new
function mv_chan_set_mode_to_desc() which allows to configure a XOR
channel to get the specific operation to be done from each individual
DMA descriptor.

However, this function was mainly a duplicate of the existing
mv_chan_set_mode(), with just the operation being different.

This commit re-organizes the code into a single mv_chan_set_mode()
function, which takes the operation mode as argument, and the
mv_xor_channel_add() function decides whether to use
XOR_OPERATION_MODE_IN_DESC or XOR_OPERATION_MODE_XOR.

Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Reviewed-by: default avatarMaxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: default avatarVinod Koul <vinod.koul@intel.com>
parent 7cbafa09
Loading
Loading
Loading
Loading
+3 −38
Original line number Original line Diff line number Diff line
@@ -139,45 +139,10 @@ static void mv_chan_clear_err_status(struct mv_xor_chan *chan)
}
}


static void mv_chan_set_mode(struct mv_xor_chan *chan,
static void mv_chan_set_mode(struct mv_xor_chan *chan,
			     enum dma_transaction_type type)
			     u32 op_mode)
{
{
	u32 op_mode;
	u32 config = readl_relaxed(XOR_CONFIG(chan));
	u32 config = readl_relaxed(XOR_CONFIG(chan));


	switch (type) {
	case DMA_XOR:
		op_mode = XOR_OPERATION_MODE_XOR;
		break;
	case DMA_MEMCPY:
		op_mode = XOR_OPERATION_MODE_MEMCPY;
		break;
	default:
		dev_err(mv_chan_to_devp(chan),
			"error: unsupported operation %d\n",
			type);
		BUG();
		return;
	}

	config &= ~0x7;
	config |= op_mode;

#if defined(__BIG_ENDIAN)
	config |= XOR_DESCRIPTOR_SWAP;
#else
	config &= ~XOR_DESCRIPTOR_SWAP;
#endif

	writel_relaxed(config, XOR_CONFIG(chan));
}

static void mv_chan_set_mode_to_desc(struct mv_xor_chan *chan)
{
	u32 op_mode;
	u32 config = readl_relaxed(XOR_CONFIG(chan));

	op_mode = XOR_OPERATION_MODE_IN_DESC;

	config &= ~0x7;
	config &= ~0x7;
	config |= op_mode;
	config |= op_mode;


@@ -1042,9 +1007,9 @@ mv_xor_channel_add(struct mv_xor_device *xordev,
	mv_chan_unmask_interrupts(mv_chan);
	mv_chan_unmask_interrupts(mv_chan);


	if (mv_chan->op_in_desc == XOR_MODE_IN_DESC)
	if (mv_chan->op_in_desc == XOR_MODE_IN_DESC)
		mv_chan_set_mode_to_desc(mv_chan);
		mv_chan_set_mode(mv_chan, XOR_OPERATION_MODE_IN_DESC);
	else
	else
		mv_chan_set_mode(mv_chan, DMA_XOR);
		mv_chan_set_mode(mv_chan, XOR_OPERATION_MODE_XOR);


	spin_lock_init(&mv_chan->lock);
	spin_lock_init(&mv_chan->lock);
	INIT_LIST_HEAD(&mv_chan->chain);
	INIT_LIST_HEAD(&mv_chan->chain);