Commit 18478af5 authored by David Brownell's avatar David Brownell Committed by Kevin Hilman

EDMA renames: remaining parameter RAM ops

This patch primarily renames functions to use an edma_ prefix and remove
a needless infix "_dma_" token ... except that "src_params" became "src",
and "dest_params" became "dest".  Parameters which identify parameter RAM
slots were renamed as "slot" from "lch".

Also, the slot numbers become unsigned (supporting a minor code shrink),
and a handful of needless temporary variables were removed.
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
parent b69e435d
...@@ -754,22 +754,21 @@ EXPORT_SYMBOL(edma_free_slot); ...@@ -754,22 +754,21 @@ EXPORT_SYMBOL(edma_free_slot);
/* Parameter RAM operations (i) -- read/write partial slots */ /* Parameter RAM operations (i) -- read/write partial slots */
/** /**
* davinci_set_dma_src_params - set initial DMA source address in PaRAM * edma_set_src - set initial DMA source address in parameter RAM slot
* @lch: logical channel being configured * @slot: parameter RAM slot being configured
* @src_port: physical address of source (memory, controller FIFO, etc) * @src_port: physical address of source (memory, controller FIFO, etc)
* @addressMode: INCR, except in very rare cases * @addressMode: INCR, except in very rare cases
* @fifoWidth: ignored unless @addressMode is FIFO, else specifies the * @fifoWidth: ignored unless @addressMode is FIFO, else specifies the
* width to use when addressing the fifo (e.g. W8BIT, W32BIT) * width to use when addressing the fifo (e.g. W8BIT, W32BIT)
* *
* Note that the source address is modified during the DMA transfer * Note that the source address is modified during the DMA transfer
* according to davinci_set_dma_src_index(). * according to edma_set_src_index().
*/ */
void davinci_set_dma_src_params(int lch, dma_addr_t src_port, void edma_set_src(unsigned slot, dma_addr_t src_port,
enum address_mode mode, enum fifo_width width) enum address_mode mode, enum fifo_width width)
{ {
if (lch >= 0 && lch < DAVINCI_EDMA_NUM_PARAMENTRY) { if (slot < DAVINCI_EDMA_NUM_PARAMENTRY) {
int j = lch; unsigned int i = edma_parm_read(PARM_OPT, slot);
unsigned int i = edma_parm_read(PARM_OPT, j);
if (mode) { if (mode) {
/* set SAM and program FWID */ /* set SAM and program FWID */
...@@ -778,32 +777,31 @@ void davinci_set_dma_src_params(int lch, dma_addr_t src_port, ...@@ -778,32 +777,31 @@ void davinci_set_dma_src_params(int lch, dma_addr_t src_port,
/* clear SAM */ /* clear SAM */
i &= ~SAM; i &= ~SAM;
} }
edma_parm_write(PARM_OPT, j, i); edma_parm_write(PARM_OPT, slot, i);
/* set the source port address /* set the source port address
in source register of param structure */ in source register of param structure */
edma_parm_write(PARM_SRC, j, src_port); edma_parm_write(PARM_SRC, slot, src_port);
} }
} }
EXPORT_SYMBOL(davinci_set_dma_src_params); EXPORT_SYMBOL(edma_set_src);
/** /**
* davinci_set_dma_dest_params - set initial DMA destination address in PaRAM * edma_set_dest - set initial DMA destination address in parameter RAM slot
* @lch: logical channel being configured * @slot: parameter RAM slot being configured
* @dest_port: physical address of destination (memory, controller FIFO, etc) * @dest_port: physical address of destination (memory, controller FIFO, etc)
* @addressMode: INCR, except in very rare cases * @addressMode: INCR, except in very rare cases
* @fifoWidth: ignored unless @addressMode is FIFO, else specifies the * @fifoWidth: ignored unless @addressMode is FIFO, else specifies the
* width to use when addressing the fifo (e.g. W8BIT, W32BIT) * width to use when addressing the fifo (e.g. W8BIT, W32BIT)
* *
* Note that the destination address is modified during the DMA transfer * Note that the destination address is modified during the DMA transfer
* according to davinci_set_dma_dest_index(). * according to edma_set_dest_index().
*/ */
void davinci_set_dma_dest_params(int lch, dma_addr_t dest_port, void edma_set_dest(unsigned slot, dma_addr_t dest_port,
enum address_mode mode, enum fifo_width width) enum address_mode mode, enum fifo_width width)
{ {
if (lch >= 0 && lch < DAVINCI_EDMA_NUM_PARAMENTRY) { if (slot < DAVINCI_EDMA_NUM_PARAMENTRY) {
int j = lch; unsigned int i = edma_parm_read(PARM_OPT, slot);
unsigned int i = edma_parm_read(PARM_OPT, j);
if (mode) { if (mode) {
/* set DAM and program FWID */ /* set DAM and program FWID */
...@@ -812,17 +810,17 @@ void davinci_set_dma_dest_params(int lch, dma_addr_t dest_port, ...@@ -812,17 +810,17 @@ void davinci_set_dma_dest_params(int lch, dma_addr_t dest_port,
/* clear DAM */ /* clear DAM */
i &= ~DAM; i &= ~DAM;
} }
edma_parm_write(PARM_OPT, j, i); edma_parm_write(PARM_OPT, slot, i);
/* set the destination port address /* set the destination port address
in dest register of param structure */ in dest register of param structure */
edma_parm_write(PARM_DST, j, dest_port); edma_parm_write(PARM_DST, slot, dest_port);
} }
} }
EXPORT_SYMBOL(davinci_set_dma_dest_params); EXPORT_SYMBOL(edma_set_dest);
/** /**
* davinci_set_dma_src_index - configure DMA source address indexing * edma_set_src_index - configure DMA source address indexing
* @lch: logical channel being configured * @slot: parameter RAM slot being configured
* @src_bidx: byte offset between source arrays in a frame * @src_bidx: byte offset between source arrays in a frame
* @src_cidx: byte offset between source frames in a block * @src_cidx: byte offset between source frames in a block
* *
...@@ -830,20 +828,20 @@ EXPORT_SYMBOL(davinci_set_dma_dest_params); ...@@ -830,20 +828,20 @@ EXPORT_SYMBOL(davinci_set_dma_dest_params);
* memory transfers, or repeated access to a hardware register, as needed. * memory transfers, or repeated access to a hardware register, as needed.
* When accessing hardware registers, both offsets are normally zero. * When accessing hardware registers, both offsets are normally zero.
*/ */
void davinci_set_dma_src_index(int lch, s16 src_bidx, s16 src_cidx) void edma_set_src_index(unsigned slot, s16 src_bidx, s16 src_cidx)
{ {
if (lch >= 0 && lch < DAVINCI_EDMA_NUM_PARAMENTRY) { if (slot < DAVINCI_EDMA_NUM_PARAMENTRY) {
edma_parm_modify(PARM_SRC_DST_BIDX, lch, edma_parm_modify(PARM_SRC_DST_BIDX, slot,
0xffff0000, src_bidx); 0xffff0000, src_bidx);
edma_parm_modify(PARM_SRC_DST_CIDX, lch, edma_parm_modify(PARM_SRC_DST_CIDX, slot,
0xffff0000, src_cidx); 0xffff0000, src_cidx);
} }
} }
EXPORT_SYMBOL(davinci_set_dma_src_index); EXPORT_SYMBOL(edma_set_src_index);
/** /**
* davinci_set_dma_dest_index - configure DMA destination address indexing * edma_set_dest_index - configure DMA destination address indexing
* @lch: logical channel being configured * @slot: parameter RAM slot being configured
* @dest_bidx: byte offset between destination arrays in a frame * @dest_bidx: byte offset between destination arrays in a frame
* @dest_cidx: byte offset between destination frames in a block * @dest_cidx: byte offset between destination frames in a block
* *
...@@ -851,20 +849,20 @@ EXPORT_SYMBOL(davinci_set_dma_src_index); ...@@ -851,20 +849,20 @@ EXPORT_SYMBOL(davinci_set_dma_src_index);
* memory transfers, or repeated access to a hardware register, as needed. * memory transfers, or repeated access to a hardware register, as needed.
* When accessing hardware registers, both offsets are normally zero. * When accessing hardware registers, both offsets are normally zero.
*/ */
void davinci_set_dma_dest_index(int lch, s16 dest_bidx, s16 dest_cidx) void edma_set_dest_index(unsigned slot, s16 dest_bidx, s16 dest_cidx)
{ {
if (lch >= 0 && lch < DAVINCI_EDMA_NUM_PARAMENTRY) { if (slot < DAVINCI_EDMA_NUM_PARAMENTRY) {
edma_parm_modify(PARM_SRC_DST_BIDX, lch, edma_parm_modify(PARM_SRC_DST_BIDX, slot,
0x0000ffff, dest_bidx << 16); 0x0000ffff, dest_bidx << 16);
edma_parm_modify(PARM_SRC_DST_CIDX, lch, edma_parm_modify(PARM_SRC_DST_CIDX, slot,
0x0000ffff, dest_cidx << 16); 0x0000ffff, dest_cidx << 16);
} }
} }
EXPORT_SYMBOL(davinci_set_dma_dest_index); EXPORT_SYMBOL(edma_set_dest_index);
/** /**
* davinci_set_dma_transfer_params - configure DMA transfer parameters * edma_set_transfer_params - configure DMA transfer parameters
* @lch: logical channel being configured * @slot: parameter RAM slot being configured
* @acnt: how many bytes per array (at least one) * @acnt: how many bytes per array (at least one)
* @bcnt: how many arrays per frame (at least one) * @bcnt: how many arrays per frame (at least one)
* @ccnt: how many frames per block (at least one) * @ccnt: how many frames per block (at least one)
...@@ -891,25 +889,23 @@ EXPORT_SYMBOL(davinci_set_dma_dest_index); ...@@ -891,25 +889,23 @@ EXPORT_SYMBOL(davinci_set_dma_dest_index);
* transfer one frame to (or from) the FIFO. It will probably use * transfer one frame to (or from) the FIFO. It will probably use
* efficient burst modes to access memory. * efficient burst modes to access memory.
*/ */
void davinci_set_dma_transfer_params(int lch, void edma_set_transfer_params(unsigned slot,
u16 acnt, u16 bcnt, u16 ccnt, u16 acnt, u16 bcnt, u16 ccnt,
u16 bcnt_rld, enum sync_dimension sync_mode) u16 bcnt_rld, enum sync_dimension sync_mode)
{ {
if (lch >= 0 && lch < DAVINCI_EDMA_NUM_PARAMENTRY) { if (slot < DAVINCI_EDMA_NUM_PARAMENTRY) {
int j = lch; edma_parm_modify(PARM_LINK_BCNTRLD, slot,
edma_parm_modify(PARM_LINK_BCNTRLD, j,
0x0000ffff, bcnt_rld << 16); 0x0000ffff, bcnt_rld << 16);
if (sync_mode == ASYNC) if (sync_mode == ASYNC)
edma_parm_and(PARM_OPT, j, ~SYNCDIM); edma_parm_and(PARM_OPT, slot, ~SYNCDIM);
else else
edma_parm_or(PARM_OPT, j, SYNCDIM); edma_parm_or(PARM_OPT, slot, SYNCDIM);
/* Set the acount, bcount, ccount registers */ /* Set the acount, bcount, ccount registers */
edma_parm_write(PARM_A_B_CNT, j, (bcnt << 16) | acnt); edma_parm_write(PARM_A_B_CNT, slot, (bcnt << 16) | acnt);
edma_parm_write(PARM_CCNT, j, ccnt); edma_parm_write(PARM_CCNT, slot, ccnt);
} }
} }
EXPORT_SYMBOL(davinci_set_dma_transfer_params); EXPORT_SYMBOL(edma_set_transfer_params);
/** /**
* edma_link - link one parameter RAM slot to another * edma_link - link one parameter RAM slot to another
......
...@@ -195,13 +195,13 @@ int edma_alloc_slot(int slot); ...@@ -195,13 +195,13 @@ int edma_alloc_slot(int slot);
void edma_free_slot(unsigned slot); void edma_free_slot(unsigned slot);
/* calls that operate on part of a parameter RAM slot */ /* calls that operate on part of a parameter RAM slot */
void davinci_set_dma_src_params(int lch, dma_addr_t src_port, void edma_set_src(unsigned slot, dma_addr_t src_port,
enum address_mode mode, enum fifo_width); enum address_mode mode, enum fifo_width);
void davinci_set_dma_dest_params(int lch, dma_addr_t dest_port, void edma_set_dest(unsigned slot, dma_addr_t dest_port,
enum address_mode mode, enum fifo_width); enum address_mode mode, enum fifo_width);
void davinci_set_dma_src_index(int lch, s16 src_bidx, s16 src_cidx); void edma_set_src_index(unsigned slot, s16 src_bidx, s16 src_cidx);
void davinci_set_dma_dest_index(int lch, s16 dest_bidx, s16 dest_cidx); void edma_set_dest_index(unsigned slot, s16 dest_bidx, s16 dest_cidx);
void davinci_set_dma_transfer_params(int lch, u16 acnt, u16 bcnt, u16 ccnt, void edma_set_transfer_params(unsigned slot, u16 acnt, u16 bcnt, u16 ccnt,
u16 bcnt_rld, enum sync_dimension sync_mode); u16 bcnt_rld, enum sync_dimension sync_mode);
void edma_link(unsigned from, unsigned to); void edma_link(unsigned from, unsigned to);
void edma_unlink(unsigned from); void edma_unlink(unsigned from);
......
...@@ -442,7 +442,7 @@ static void mmc_davinci_dma_cb(unsigned channel, u16 ch_status, void *data) ...@@ -442,7 +442,7 @@ static void mmc_davinci_dma_cb(unsigned channel, u16 ch_status, void *data)
static void __init mmc_davinci_dma_setup(struct mmc_davinci_host *host, static void __init mmc_davinci_dma_setup(struct mmc_davinci_host *host,
bool tx, struct edmacc_param *template) bool tx, struct edmacc_param *template)
{ {
int sync_dev; unsigned sync_dev;
const u16 acnt = 4; const u16 acnt = 4;
const u16 bcnt = rw_threshold >> 2; const u16 bcnt = rw_threshold >> 2;
const u16 ccnt = 0; const u16 ccnt = 0;
...@@ -488,13 +488,13 @@ static void __init mmc_davinci_dma_setup(struct mmc_davinci_host *host, ...@@ -488,13 +488,13 @@ static void __init mmc_davinci_dma_setup(struct mmc_davinci_host *host,
* are not 256-bit (32-byte) aligned. So we use INCR, and the W8BIT * are not 256-bit (32-byte) aligned. So we use INCR, and the W8BIT
* parameter is ignored. * parameter is ignored.
*/ */
davinci_set_dma_src_params(sync_dev, src_port, INCR, W8BIT); edma_set_src(sync_dev, src_port, INCR, W8BIT);
davinci_set_dma_dest_params(sync_dev, dst_port, INCR, W8BIT); edma_set_dest(sync_dev, dst_port, INCR, W8BIT);
davinci_set_dma_src_index(sync_dev, src_bidx, src_cidx); edma_set_src_index(sync_dev, src_bidx, src_cidx);
davinci_set_dma_dest_index(sync_dev, dst_bidx, dst_cidx); edma_set_dest_index(sync_dev, dst_bidx, dst_cidx);
davinci_set_dma_transfer_params(sync_dev, acnt, bcnt, ccnt, 8, ABSYNC); edma_set_transfer_params(sync_dev, acnt, bcnt, ccnt, 8, ABSYNC);
edma_read_slot(sync_dev, template); edma_read_slot(sync_dev, template);
......
...@@ -97,11 +97,11 @@ static void davinci_pcm_enqueue_dma(struct snd_pcm_substream *substream) ...@@ -97,11 +97,11 @@ static void davinci_pcm_enqueue_dma(struct snd_pcm_substream *substream)
dst_bidx = data_type; dst_bidx = data_type;
} }
davinci_set_dma_src_params(lch, src, INCR, W8BIT); edma_set_src(lch, src, INCR, W8BIT);
davinci_set_dma_dest_params(lch, dst, INCR, W8BIT); edma_set_dest(lch, dst, INCR, W8BIT);
davinci_set_dma_src_index(lch, src_bidx, 0); edma_set_src_index(lch, src_bidx, 0);
davinci_set_dma_dest_index(lch, dst_bidx, 0); edma_set_dest_index(lch, dst_bidx, 0);
davinci_set_dma_transfer_params(lch, data_type, count, 1, 0, ASYNC); edma_set_transfer_params(lch, data_type, count, 1, 0, ASYNC);
prtd->period++; prtd->period++;
if (unlikely(prtd->period >= runtime->periods)) if (unlikely(prtd->period >= runtime->periods))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment