[alsa-devel] Build regressions/improvements in v3.0-rc7 (sound/isa/)
Takashi Iwai
tiwai at suse.de
Thu Jul 28 20:11:41 CEST 2011
At Thu, 28 Jul 2011 13:06:19 -0400,
Arnaud Lacombe wrote:
>
> Hi,
>
> On Thu, Jul 28, 2011 at 12:44 PM, Randy Dunlap <rdunlap at xenotime.net> wrote:
> > On Thu, 28 Jul 2011 12:36:27 -0400 Arnaud Lacombe wrote:
> >
> >> Hi,
> >>
> >> On Thu, Jul 28, 2011 at 12:21 PM, Randy Dunlap <rdunlap at xenotime.net> wrote:
> >> > On Thu, 28 Jul 2011 11:17:09 +1000 Stephen Rothwell wrote:
> >> >
> >> >> Hi Randy,
> >> >>
> >> >> On Wed, 27 Jul 2011 12:13:20 -0700 Randy Dunlap <rdunlap at xenotime.net> wrote:
> >> >> >
> >> >> > On Mon, 25 Jul 2011 09:10:03 -0700 Randy Dunlap wrote:
> >> >> >
> >> >> > > On Mon, 25 Jul 2011 09:37:53 +0200 Takashi Iwai wrote:
> >> >> > >
> >> >> > > > At Sun, 24 Jul 2011 12:26:24 -0700,
> >> >> > > > Randy Dunlap wrote:
> >> >> > > > >
> >> >> > > > > On Wed, 13 Jul 2011 21:33:30 +0200 Geert Uytterhoeven wrote:
> >> >> > > > >
> >> >> > > > > > + src/sound/isa/ad1816a/ad1816a_lib.c: error: implicit declaration of function 'snd_dma_disable': => 544
> >> >> > > > > > + src/sound/isa/ad1816a/ad1816a_lib.c: error: implicit declaration of function 'snd_dma_pointer': => 302
> >> >> > > > > > + src/sound/isa/ad1816a/ad1816a_lib.c: error: implicit declaration of function 'snd_dma_program': => 244
> >> >> > > > > > + src/sound/isa/es1688/es1688_lib.c: error: implicit declaration of function 'snd_dma_pointer': => 509
> >> >> > > > > > + src/sound/isa/es1688/es1688_lib.c: error: implicit declaration of function 'snd_dma_program': => 417
> >> >> > > > > > + src/sound/isa/gus/gus_dma.c: error: implicit declaration of function 'snd_dma_disable': => 177
> >> >> > > > > > + src/sound/isa/gus/gus_dma.c: error: implicit declaration of function 'snd_dma_program': => 79
> >> >> > > > > > + src/sound/isa/gus/gus_pcm.c: error: implicit declaration of function 'snd_dma_pointer': => 619
> >> >> > > > > > + src/sound/isa/gus/gus_pcm.c: error: implicit declaration of function 'snd_dma_program': => 591
> >> >> > > > > > + src/sound/isa/sb/sb16_main.c: error: implicit declaration of function 'snd_dma_pointer': => 456
> >> >> > > > > > + src/sound/isa/sb/sb16_main.c: error: implicit declaration of function 'snd_dma_program': => 276
> >> >> > > > > > + src/sound/isa/sb/sb8_main.c: error: implicit declaration of function 'snd_dma_pointer': => 425
> >> >> > > > > > + src/sound/isa/sb/sb8_main.c: error: implicit declaration of function 'snd_dma_program': => 172
> >> >> > > > > > + src/sound/isa/sscape.c: error: implicit declaration of function 'snd_dma_program': => 481
> >> >> > > > > > + src/sound/isa/wss/wss_lib.c: error: implicit declaration of function 'snd_dma_disable': => 1695
> >> >> > > > > > + src/sound/isa/wss/wss_lib.c: error: implicit declaration of function 'snd_dma_pointer': => 1160
> >> >> > > > > > + src/sound/isa/wss/wss_lib.c: error: implicit declaration of function 'snd_dma_program': => 1025
> >> >> > > > >
> >> >> > > > > All of these source files do #include <sound/core.h>,
> >> >> > > > > but these missing/implicit functions are conditional:
> >> >> > > > >
> >> >> > > > > #ifdef CONFIG_ISA_DMA_API
> >> >> > > > > #define DMA_MODE_NO_ENABLE 0x0100
> >> >> > > > >
> >> >> > > > > void snd_dma_program(unsigned long dma, unsigned long addr, unsigned int size, unsigned short mode);
> >> >> > > > > void snd_dma_disable(unsigned long dma);
> >> >> > > > > unsigned int snd_dma_pointer(unsigned long dma, unsigned int size);
> >> >> > > > > #endif
> >> >> > > > >
> >> >> > > > > so should these drivers all depend on ISA_DMA_API ?
> >> >> > > >
> >> >> > > > Yes, these are ISA sound cards, so they must have CONFIG_ISA and
> >> >> > > > CONFIG_ISA_DMA. Although CONFIG_SND_SB8_DSP, CONFIG_SND_SB16_DSP
> >> >> > > > and CONFIG_SND_WSS_LIB have no direct dependency, but the drivers
> >> >> > > > selecting these are all in "if SND_ISA" in sound/isa/Kconfig.
> >> >> > >
> >> >> > > Hm, yes, they are.
> >> >> > >
> >> >> > > > > or should only pieces of each driver depend on ISA_DMA_API ?
> >> >> > > >
> >> >> > > > I wonder which configuration makes it possible.
> >> >> > > > Did you see a similar problem with randconfig?
> >> >> > >
> >> >> > > No. This parisc allmodconfig file from linux-next builds has
> >> >> > > CONFIG_SND_ISA=y but it does not have CONFIG_ISA_DMA_API enabled. Weird.
> >> >> > >
> >> >> > > Geert, do you know how this happens?
> >> >> > >
> >> >> > > parisc config: http://kisskb.ellerman.id.au/kisskb/buildresult/4323458/config/
> >> >> > > from this failed build: http://kisskb.ellerman.id.au/kisskb/buildresult/4323458/
> >> >> >
> >> >> > How is CONFIG_ISA_DMA_API enabled in parisc allmodconfig?
> >> >> > I don't see how that happens, and it's causing build errors...
> >> >>
> >> >> Sorry, but I don't understand the question. The problam is that
> >> >> CONFIG_ISA_DMA_API is not enabled, right? On parisc, it is just (from
> >> >> arch/parisc/Kconfig)
> >> >>
> >> >> config ISA_DMA_API
> >> >> bool
> >> >>
> >> >> and nothing selects it. However, I would have expected an allmodconfig
> >> >> to set it to y. Clearly I don't understan how allmodconfig works any
> >> >> more :-(
> >> >>
> >> >> Michal, is my understanding correct? Is this a bug in allmodconfig?
> >> >
> >> > When I do:
> >> > $ make ARCH=parisc O=PAR allmodconfig
> >> >
> >> > I don't get CONFIG_ISA_DMA_API enabled, so the question is simply
> >> > how is the linux-next build system ending up with CONFIG_ISA_DMA_API enabled?
> >> >
> >> Where do you see that "linux-next build system ending up with
> >> CONFIG_ISA_DMA_API enabled" ?
> >>
> >> From what I understood of the problem, the issue is that
> >> CONFIG_ISA_DMA_API does _not_ ends up enabled.
> >
> > Thanks for catching me.
> >
> > The problem (second try) is that ISA SND drivers are being built (on parisc)
> > even though ISA_DMA_API is not enabled -- and should not be enabled,
> > so the ISA SND drivers should not be built. I think I have it right this time.
> >
> > From the parisc .config file listed above:
> >
> > CONFIG_SND_ISA=y
> > CONFIG_SND_ADLIB=m
> > CONFIG_SND_AD1816A=m
> > CONFIG_SND_AD1848=m
> > CONFIG_SND_ALS100=m
> > CONFIG_SND_AZT1605=m
> > CONFIG_SND_AZT2316=m
> > CONFIG_SND_AZT2320=m
> > CONFIG_SND_CMI8330=m
> >
> >
> > etc. But none of these should be enabled. AFAIK.
> > So how does this happen?
> >
> warning: (RADIO_MIROPCM20) selects SND_ISA which has unmet direct
> dependencies (SOUND && !M68K && SND && ISA && ISA_DMA_API)
Hm, I thought this was fixed by
commit 4756fc64ecd628efa6f8296711d7dbcefabf25dd
Author: Ralf Baechle <ralf at linux-mips.org>
Date: Fri Jun 24 10:30:09 2011 -0300
[media] MEDIA: Fix non-ISA_DMA_API link failure of sound code
OK, it landed after 3.0-rc7, so this problem must be fixed now?
I'm not sure at which point this thread is focused on.
Takashi
More information about the Alsa-devel
mailing list