From mboxrd@z Thu Jan 1 00:00:00 1970 From: Carlos Chinea Subject: Re: [RFC PATCHv2 2/7] OMAP SSI: Introducing OMAP SSI driver Date: Wed, 26 May 2010 10:27:13 +0300 Message-ID: <1274858833.8099.14.camel@localhost> References: <1273245517-30712-1-git-send-email-carlos.chinea@nokia.com> <201005141641.59244.s-jan@ti.com> <1274173640.7755.22703.camel@localhost> <201005181605.55809.s-jan@ti.com> Mime-Version: 1.0 Content-Type: text/plain Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <201005181605.55809.s-jan@ti.com> Sender: linux-kernel-owner@vger.kernel.org To: ext Sebastien Jan Cc: "linux-kernel@vger.kernel.org" , "linux-omap@vger.kernel.org" List-Id: linux-omap@vger.kernel.org On Tue, 2010-05-18 at 16:05 +0200, ext Sebastien Jan wrote: > On Tuesday 18 May 2010 11:07:20 Carlos Chinea wrote: > [cut] > > > > + val |= __raw_readl(omap_ssi->sys + > > > > SSI_MPU_ENABLE_REG(port->num, 0)); + __raw_writel(val, > > > > omap_ssi->sys + > > > > SSI_MPU_ENABLE_REG(port->num, 0)); + > > > > + msg->status = HSI_STATUS_COMPLETED; > > > > + msg->actual_len = sg_dma_len(msg->sgt.sgl); > > > > + spin_unlock(&omap_ssi->lock); > > > > +} > > > > > > Don't you need to check the queue related to this transfer at this point, > > > to start the potentially next queued transfer on the same channel? > > > (calling ssi_start_transfer(), like in ssi_pio_complete()?) > > > > No this is done in ssi_pio_complete(). Notice that we do not call the > > complete callback at any point here. We just arm the pio interrupt for > > that channel and transfer direction. AFAIK, this is the SW logic > > expected by the OMAP SSI HW. > > Ok, though I would not expect the interrupt to fire in an Rx scenario as the > fifo would have already been emptied by the DMA for this transfer (unless you > rely on the next transfer initiated by the peer to make the Rx interrupt fire > on this channel?)? No I do not rely on the next RX transfer. I rely on the fact that the GDD(DMA) controller does not reset the RX status bit for that channel when RX transfer is finished. Br, -- Carlos Chinea