From: Linus Walleij on
2010/7/20 Koul, Vinod <vinod.koul(a)intel.com>:

> /**
> �* struct intel_mid_dma_slave - DMA slave structure
> �*
> �* @dirn: DMA trf direction
> �* @src_width: tx register width
> �* @dst_width: rx register width
> �* @hs_mode: HW/SW handshaking mode
> �* @cfg_mode: DMA data transfer mode (per-per/mem-per/mem-mem)
> �* @src_msize: Source DMA burst size
> �* @dst_msize: Dst DMA burst size
> �* @device_instance: DMA peripheral device instance, we can have multiple
> �* � � � � � � � � � � �peripheral device connected to single DMAC
> �*/
> struct intel_mid_dma_slave {
> � � � �enum dma_data_direction � � � � dirn;
> � � � �enum intel_mid_dma_width � � � �src_width; /*width of DMA src txn*/
> � � � �enum intel_mid_dma_width � � � �dst_width; /*width of DMA dst txn*/
> � � � �enum intel_mid_dma_hs_mode � � �hs_mode; �/*handshaking*/
> � � � �enum intel_mid_dma_mode � � � � cfg_mode; /*mode configuration*/
> � � � �enum intel_mid_dma_msize � � � �src_msize; /*size if src burst*/
> � � � �enum intel_mid_dma_msize � � � �dst_msize; /*size of dst burst*/
> � � � �unsigned int � � � � � �device_instance; /*0, 1 for peripheral instance*/
> };
>
> Yes the structures have various common things and would be good to abstract
> generic stuff in this and move the rest to private_config.
> But since we are talking about a generic DMA slave capabilities structure, I
> would recommend changing few.
>
> I am not sure why do you want the I/O addr to be passed here, sorry I
> don't follow that logic. If you notice in intel_mid_dma driver the I/O address
> is passed by client driver in prep_memcpy in src and dst fields. Since the slave
> structure tell you the direction and mode you can interpret that src/dst address
> as IO address easily

? Are you using memcpy() to talk to slaves?

I was assuming all slave communication was to use sglists through
the .device_prep_slave_sg() call. This is currently the design constraint,
memcpy() will by design increase both source and destination address
and also always operate on the memory bus.

(If you need reconfiguration also for memcpy() I think will be a
different issue, I'm only looking at slaves now.)

With only the slave interface the dma_chan struct can be deferred
by the DMA engine into a local struct which has this address configured
from the platform, statically.

The runtime configuration API is exactly about being able to reconfigure
even the source/destination address at runtime. This is why
these are on the interface.

> Addr_width and Maxburst: talks about the I/O width and msize I guess, but what
> about mem-width, I have few configuration where we would like to have different
> mem width as well.

OK then we need that for both src and dst.

> And why limit the generic API

Just trying to see how small we can get it, less things can go wrong.

> and what about per-per transfers which
> intel_mid_dma driver would need to support in future.

Yep per2per will definately need that.

> I would recommend renaming this field to src_addr_width
> etc and add dst_addr_xxx
> pair.

OK if Dan agrees I'll make a try.

> Yes I can have them in private_config but then again driver has to do a simple
> check on which one is src/dst in slave and which one is in privae_config. Again
> easily doable but little confusing, I am okay either way

No if you're already foreseeing that they'll be needed, lets put
them in from the beginning...

Yours,
Linus Walleij
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo(a)vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
From: Koul, Vinod on
> ? Are you using memcpy() to talk to slaves?
Yes, I don't have sg support yet, that's something I need to add next.

> I was assuming all slave communication was to use sglists through
> the .device_prep_slave_sg() call. This is currently the design constraint,
> memcpy() will by design increase both source and destination address
> and also always operate on the memory bus.
>
> (If you need reconfiguration also for memcpy() I think will be a
> different issue, I'm only looking at slaves now.)
>
> With only the slave interface the dma_chan struct can be deferred
> by the DMA engine into a local struct which has this address configured
> from the platform, statically.
>
> The runtime configuration API is exactly about being able to reconfigure
> even the source/destination address at runtime. This is why
> these are on the interface.
Okay looking at the sg API, now I can understand why you need the address in
this structure, I would also need that in future.
One suggestion since we are giving io address here, how about naming the
variable as io_addr, and we can add comment to be used for sg operations as io
addr if anyone wants to use memcpy() they can ignore this


Thanks
Vinod
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo(a)vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/