[alsa-devel] [PATCH 2/2] sis7019: add support for pre-2.6 kernels
Clemens Ladisch
cladisch at fastmail.net
Mon Dec 10 15:48:44 CET 2007
Dave Dillow wrote:
> On Mon, 2007-12-10 at 08:53 +0100, Clemens Ladisch wrote:
> > Dave Dillow wrote:
> > > The sis7019 driver uses __ffs(), which is available in 2.6 kernels, but
> > > not in most earlier ones. This patches the driver to use a local version
> > > assembly version, as the hardware is SiS 55x only (i486/Pentium-ish).
> > >
> > > ++#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0)
> > > ++static inline unsigned long sis_ffs(unsigned long word)
> > > ++{
> > > ++ __asm__("bsfl %1,%0"
> > > ++ :"=r" (word)
> > > ++ :"rm" (word));
> > > ++ return word;
> > > ++}
> > > ++#endif
> >
> > This should go into alsa-driver/include/adriver.h.
>
> I'm not sure -- there's no other inline assembly there, and if I provide
> an x86 _ffs() fallback, then it'll break on other architectures...
It won't break unless another driver actually uses __ffs(), and then we
can still add a generic implementation.
Regards,
Clemens
More information about the Alsa-devel
mailing list