[Aboriginal] Merry christmas, I have found two bugs

Rob Landley rob at landley.net
Wed Dec 26 13:36:35 PST 2012


On 12/26/2012 02:55:04 PM, Bjørn Forsman wrote:
> Hi,
> 
> Since it's christmas and I have som extra time, I thought I'd play a
> bit with aboriginal :-)

Yay! Glad to have you.

> And now I think I've found two bugs. Bug 1 is
> a segmentation fault during system image boot:
> 
> $ cd build/system-image-avmv5l
> $ ./run-emulator.sh
> [...]
> Freeing init memory: 96K
> Segmentation fault
> 8139cp 0000:00:0c.0 eth0: link up, 100Mbps, full-duplex, lpa 0x05E1
> Not using distcc.
> Type exit when done.
> (armv5l:1) /home #
> 
> Not sure what exactly is segfaulting, but segfault == bug to me. And
> it only happens with ./run-emulator.sh, not ./dev-environment.sh.

There are somewhat different code paths in the init.sh shell script so  
it's probably something only running in the first case. I need to  
rebuild the armv5l target to test this, that'll take a few minutes...

> And bug 2 is a floating point exception in toybox "ls":
> $ ./dev-environment.sh
> [...]
> Freeing init memory: 96K
> 8139cp 0000:00:0c.0 eth0: link up, 100Mbps, full-duplex, lpa 0x05E1
> EXT4-fs (sdb): mounting ext3 file system using the ext4 subsystem
> EXT4-fs (sdb): recovery complete
> EXT4-fs (sdb): mounted filesystem with ordered data mode. Opts: (null)
> Distcc acceleration enabled.
> Type exit when done.
> (armv5l:1) /home # ls
> Floating point exception
> (armv5l:1) /home # toybox ls
> Floating point exception
> (armv5l:1) /home # ls -l
> total 24
> drwx------ 2 root root 12288 2012-12-26 20:39 lost+found
> (armv5l:1) /home #

*boggle* That's... very strange.

(Also, I didn't think ls was using floating point? Quick check says  
it's not...)

> The really strange thing (at least to me) is that the floating point
> exception only appears in ./dev-environment.sh, NOT ./run-emulator.sh.
> And it's only "ls" that is broken, "ls -l" is ok.

Very wierd. Lemme see if I can reproduce that... yes I can. And wow,  
you're right, it's only happening for dev-environment.sh which should  
be TOTALLY unrelated...

   wget http://landley.net/aboriginal/strace-armv5l
   chmod +x strace-armv5l
   ./strace /bin/ls

execve("/bin/ls", ["/bin/ls"], [/* 9 vars */]) = 0
brk(0)                                  = 0x932000
brk(0x9324b0)                           = 0x9324b0
set_tls(0x932490, 0x5124c, 0, 0x1, 0x65fac) = 0
ioctl(0, SNDCTL_TMR_TIMEBASE or SNDRV_TIMER_IOCTL_NEXT_DEVICE or  
TCGETS, {B38400 opost isig icanon echo ...}) = 0
ioctl(1, SNDCTL_TMR_TIMEBASE or SNDRV_TIMER_IOCTL_NEXT_DEVICE or  
TCGETS, {B38400 opost isig icanon echo ...}) = 0
getuid32()                              = 0
geteuid32()                             = 0
brk(0x9334b0)                           = 0x9334b0
brk(0x934000)                           = 0x934000
umask(0)                                = 022
umask(022)                              = 0
ioctl(1, SNDCTL_TMR_TIMEBASE or SNDRV_TIMER_IOCTL_NEXT_DEVICE or  
TCGETS, {B38400 opost isig icanon echo ...}) = 0
ioctl(0, TIOCGWINSZ, {ws_row=0, ws_col=0, ws_xpixel=0, ws_ypixel=0}) = 0
ioctl(1, TIOCGWINSZ, {ws_row=0, ws_col=0, ws_xpixel=0, ws_ypixel=0}) = 0
ioctl(2, TIOCGWINSZ, {ws_row=0, ws_col=0, ws_xpixel=0, ws_ypixel=0}) = 0
newfstatat(AT_FDCWD, ".", {st_mode=S_IFDIR|0755, st_size=1024, ...}, 0)  
= 0
open(".", O_RDONLY|O_LARGEFILE)         = 3
dup(3)                                  = 4
fstat64(4, {st_mode=S_IFDIR|0755, st_size=1024, ...}) = 0
fcntl64(4, F_GETFL)                     = 0x20000 (flags  
O_RDONLY|O_LARGEFILE)
getdents64(4, /* 4 entries */, 1024)    = 120
newfstatat(4, ".", {st_mode=S_IFDIR|0755, st_size=1024, ...},  
AT_SYMLINK_NOFOLLOW) = 0
newfstatat(4, "strace-armv5l", {st_mode=S_IFREG|0755, st_size=329448,  
...}, AT_SYMLINK_NOFOLLOW) = 0
newfstatat(4, "..", {st_mode=S_IFDIR|0755, st_size=163, ...},  
AT_SYMLINK_NOFOLLOW) = 0
newfstatat(4, "lost+found", {st_mode=S_IFDIR|0700, st_size=12288, ...},  
AT_SYMLINK_NOFOLLOW) = 0
getdents64(4, /* 0 entries */, 1024)    = 0
close(4)                                = 0
gettid()                                = 49
tgkill(49, 49, SIGFPE)                  = 0
--- SIGFPE {si_signo=SIGFPE, si_code=SI_TKILL, si_pid=49, si_uid=0} ---
+++ killed by SIGFPE +++
Floating point exception

So it's getting a ways into ls. Looks like it manages the whole dirtree  
and then dies on the way back. Hmmm...

Thanks for the heads up, I'm going to chew on these for a bit...

Rob


More information about the Aboriginal mailing list