* [RFC]PPC driver lock for DMA registers
@ 2009-03-18 16:29 Eddie Dawydiuk
2009-03-18 16:40 ` Grant Likely
0 siblings, 1 reply; 3+ messages in thread
From: Eddie Dawydiuk @ 2009-03-18 16:29 UTC (permalink / raw)
To: linuxppc-dev
Hello,
I'm working on SD card and Nand drivers that I would like to eventually submit
for inclusion in the mainline kernel. This being my first kernel port being
submitted upstream I was hoping for comments on my proposed design to ensure it
would be excepted in the mainline kernel(from a design standpoint). We have an
FPGA on our product that has an interface for transferring data via DMA. The SD
card driver and Nand flash driver will both be accessing these registers. As a
result I was planning on writing a dma driver(drivers/dma/ts81xx.c) that
implements a function dma_op() that gets passed a physical address, virtual
address, length, and read/write op and returns an int. I'd use a semaphore to
protect the registers. I'd also implement a function dma_bus_init() for
allocating a cache coherent buffer, initializing the semaphore, and ioremapping
the FPGA regs.
I'd really appreciate any feedback or suggestions.
--
Best Regards,
________________________________________________________________
Eddie Dawydiuk, Technologic Systems | voice: (480) 837-5200
16525 East Laser Drive | fax: (480) 837-5300
Fountain Hills, AZ 85268 | web: www.embeddedARM.com
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [RFC]PPC driver lock for DMA registers
2009-03-18 16:29 [RFC]PPC driver lock for DMA registers Eddie Dawydiuk
@ 2009-03-18 16:40 ` Grant Likely
2009-03-18 16:53 ` Eddie Dawydiuk
0 siblings, 1 reply; 3+ messages in thread
From: Grant Likely @ 2009-03-18 16:40 UTC (permalink / raw)
To: Eddie Dawydiuk; +Cc: linuxppc-dev
On Wed, Mar 18, 2009 at 10:29 AM, Eddie Dawydiuk <eddie@embeddedarm.com> wrote:
> Hello,
>
> I'm working on SD card and Nand drivers that I would like to eventually
> submit for inclusion in the mainline kernel. This being my first kernel port
> being submitted upstream I was hoping for comments on my proposed design to
> ensure it would be excepted in the mainline kernel(from a design
> standpoint). We have an FPGA on our product that has an interface for
> transferring data via DMA. The SD card driver and Nand flash driver will
> both be accessing these registers. As a result I was planning on writing a
> dma driver(drivers/dma/ts81xx.c) that implements a function dma_op() that
> gets passed a physical address, virtual address, length, and read/write op
> and returns an int. I'd use a semaphore to protect the registers. I'd also
> implement a function dma_bus_init() for allocating a cache coherent buffer,
> initializing the semaphore, and ioremapping the FPGA regs.
Nothing that you describe here sounds off base, but the proof is in
the pudding so they say. Best advice I can offer is to follow the
example of existing powerpc device drivers. You'll need to describe
your FPGA interface in the .dts file and write an of_platform driver
that binds against it. Make sure you post your proposed dts
description of the FPGA to the devicetree-discuss@ozlabs.org mailing
list before committing to it. In you're device drivers .probe() hook
you would create and register the NAND and SD devices with the kernel
with the needed hooks to access the FPGA.
Here are some good examples of of_platform drivers to look at:
drivers/block/xsysace.c
drivers/spi/xilinx_spi.c
drivers/i2c/busses/i2c-ibm_iic.c
Cheers,
g.
--
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [RFC]PPC driver lock for DMA registers
2009-03-18 16:40 ` Grant Likely
@ 2009-03-18 16:53 ` Eddie Dawydiuk
0 siblings, 0 replies; 3+ messages in thread
From: Eddie Dawydiuk @ 2009-03-18 16:53 UTC (permalink / raw)
To: Grant Likely; +Cc: linuxppc-dev
Hello,
>> I'm working on SD card and Nand drivers that I would like to eventually
>> submit for inclusion in the mainline kernel. This being my first kernel port
>> being submitted upstream I was hoping for comments on my proposed design to
>> ensure it would be excepted in the mainline kernel(from a design
>> standpoint). We have an FPGA on our product that has an interface for
>> transferring data via DMA. The SD card driver and Nand flash driver will
>> both be accessing these registers. As a result I was planning on writing a
>> dma driver(drivers/dma/ts81xx.c) that implements a function dma_op() that
>> gets passed a physical address, virtual address, length, and read/write op
>> and returns an int. I'd use a semaphore to protect the registers. I'd also
>> implement a function dma_bus_init() for allocating a cache coherent buffer,
>> initializing the semaphore, and ioremapping the FPGA regs.
>
> Nothing that you describe here sounds off base, but the proof is in
> the pudding so they say. Best advice I can offer is to follow the
> example of existing powerpc device drivers. You'll need to describe
> your FPGA interface in the .dts file and write an of_platform driver
> that binds against it. Make sure you post your proposed dts
> description of the FPGA to the devicetree-discuss@ozlabs.org mailing
> list before committing to it. In you're device drivers .probe() hook
> you would create and register the NAND and SD devices with the kernel
> with the needed hooks to access the FPGA.
>
> Here are some good examples of of_platform drivers to look at:
>
> drivers/block/xsysace.c
> drivers/spi/xilinx_spi.c
> drivers/i2c/busses/i2c-ibm_iic.c
Thanks for the suggestions, and the pointer to some reference drivers ;)
--
Best Regards,
________________________________________________________________
Eddie Dawydiuk, Technologic Systems | voice: (480) 837-5200
16525 East Laser Drive | fax: (480) 837-5300
Fountain Hills, AZ 85268 | web: www.embeddedARM.com
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2009-03-18 16:50 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-03-18 16:29 [RFC]PPC driver lock for DMA registers Eddie Dawydiuk
2009-03-18 16:40 ` Grant Likely
2009-03-18 16:53 ` Eddie Dawydiuk
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).