From: ing. Federico Fuga <fuga@studiofuga.com>
To: buildroot@busybox.net
Subject: [Buildroot] abi problem with arm [solves alsa-lib invalid ioctl]
Date: Thu, 22 Nov 2007 16:43:35 +0100 [thread overview]
Message-ID: <4745A3A7.2000301@studiofuga.com> (raw)
Hi,
I have found and solved the problem that breaks the ioctl of alsa-lib in
arm.
Just a little preamble:
when compiling with arm xscale on an em-x270 board, all the installation
works correctly except that the alsactl cannot set the volume levels of
mixer:
# alsactl restore
unknown ioctl = 0xc2c45513 ioctl ELEM_WRITE=0xc2c85513 struct 712
alsactl: set_control:1159: Cannot write control '2:0:0:Speaker Playback
Volume:0' : Inappropriate ioctl for device
(note that the "unknown ioctl" message is a debug message i put on the
sound/core/control.c source to get rid of the problem).
If you compile a simple program that prints the ioctl and sizeof struct
snd_ctl_elem_value, you'll notice that the structure size is 708 in this
case.
As someone pointed out, there may be an alignment problem problem in the
structure when compiled with the toolchain.
The strange thing is that a kernel compiled with this toolchain
(arm-linux-uclibc) works perfectly with all programs except that alsa,
and that if you run that kernel with a file system and alsa compiled
with glibc (angstrom linux) alsactl works perfectly.
So after 5 days of digging, I found that the alsa drivers in the kernel
are compiled with the -mabi=aapcs-linux option in gcc.
If I add that option to CFLAGS in the alsa-lib configure script and
compile, alsactl works perfectly!
So I suggest to put the option
-mabi=aapcs-linux
to all the compilation of uclibc and buildroot.
I would propose the patch, but I do not know where to put the option in
the scripts/configuration.
Hope that helps,
Federico Fuga
next reply other threads:[~2007-11-22 15:43 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-11-22 15:43 ing. Federico Fuga [this message]
2007-11-24 13:53 ` [Buildroot] abi problem with arm [solves alsa-lib invalid ioctl] Ivan Kuten
2007-11-24 15:12 ` ing. Federico Fuga
2007-11-28 7:01 ` Ulf Samuelsson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4745A3A7.2000301@studiofuga.com \
--to=fuga@studiofuga.com \
--cc=buildroot@busybox.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox