On Mon, May 18, 2009 at 11:10:12PM +0900, Atsushi Nemoto wrote: > +static int txx9aclc_ac97_probe(struct platform_device *pdev, > + struct snd_soc_dai *dai) > +{ > + struct snd_soc_device *socdev = platform_get_drvdata(pdev); > + struct txx9aclc_soc_device *dev = > + container_of(socdev, struct txx9aclc_soc_device, soc_dev); > + struct platform_device *aclc_pdev = dev->aclc_pdev; > + struct resource *r; > + int err; > + int irq; > + > + dev->irq = -1; > + irq = platform_get_irq(aclc_pdev, 0); This isn't what I meant by moving the resources to the DAI and DMA drivers. You have moved the calls to read the resources to these drivers (which is good) but the resources are still being obtained from the main ASoC device rather than by themselves from the device code. There aren't too many platforms using this approach yet but take a look at the way the pxa2xx-ac97 driver deals with registering the DAI (it doesn't do anything with resources ATM) - you want to be registering your DAI and grabbing the resources from a platform driver probe like it does.