Subject: Re: CVS commit: src/sys/dev/ieee1394
To: None <kiyohara@kk.iij4u.or.jp>
From: Izumi Tsutsui <tsutsui@ceres.dti.ne.jp>
List: source-changes
Date: 05/01/2006 21:16:33
In article <20060430.234145.28792723.kiyohara@kk.iij4u.or.jp>
kiyohara@kk.iij4u.or.jp wrote:

> The ieee1394 driver's DMA descriptor cannot be operated if it is not a
> memory of coherent now.  This is because processing that rewrites
> descriptor without stopping DMA under operation is done. 
> 
> In that case, ieee1394 today will not be able to be used.  Is there
> something any idea?

I don't think it's an ieee1394 specific problem because
many other drivers (SCSI, Ethernet) notify DMA xfer completion
via DMA descriptors. How does BUS_DMA_COHERENT
(i.e. uncached DMA descriptor) help in your ieee1394 case?

I guess it might prevent some race condition on DMA descs
which require read-modified-write ops in some case,
but it's still worth to call bus_dmamap_sync()
before and after CPU accesses to descriptors,
i.e. is there any benefits by removing sync ops?
---
Izumi Tsutsui