linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* 2.6.15 OOPS while trying to mount cdrom
@ 2006-01-10 18:46 Helge Hafting
  0 siblings, 0 replies; 4+ messages in thread
From: Helge Hafting @ 2006-01-10 18:46 UTC (permalink / raw)
  To: linux-kernel

Kernel 2.6.15 amd64, gcc 4.1.0 from debian.

The cdrom (/dev/hda) is usually fine.  I tried booting with
hda=ide-scsi in order to read a scratched audio cd with cdparanoia.
That way, I at least get error messages when the scratches are
too bad.

I forgot about hda=ide-scsi, and tried to mount /dev/hda as
usual in order to read an ordinary iso9660 cd.  This is
probably not supposed to work when ide-scsi is using the device,
but then I expect something like EBUSY rather than this oops:

ide-scsi: unsup command: dev hda: flags = REQ_SORTED REQ_CMD REQ_STARTED 
REQ_ELVPRIV 
sector 64, nr/cnr 2/2
bio ffff8100044a9b40, biotail ffff8100044a9b40, buffer ffff81000cb4d000, data 
0000000000000000, len 0
end_request: I/O error, dev hda, sector 64
isofs_fill_super: bread failed, dev=hda, iso_blknum=16, block=32
Unable to handle kernel NULL pointer dereference at 0000000000000000 RIP: 
<ffffffff80235a92>{strlen+2}
PGD 73bc067 PUD 14ecd067 PMD 0 
Oops: 0000 [1] PREEMPT 
CPU 0 
Pid: 9457, comm: mount Tainted: G   M  2.6.15 #30
RIP: 0010:[<ffffffff80235a92>] <ffffffff80235a92>{strlen+2}
RSP: 0018:ffff810006701c40  EFLAGS: 00010246
RAX: 0000000000000000 RBX: 0000000000000001 RCX: 00000000000000d0
RDX: 0000000000000000 RSI: 00000000000000d0 RDI: 0000000000000000
RBP: ffff81001f9a68a8 R08: ffff810006700000 R09: ffff81001ef39d80
R10: 000000000000002b R11: 0000000000000246 R12: ffff81001f9a68a8
R13: 00000000000000d0 R14: 0000000000000000 R15: ffff810002825000
FS:  00002aaaab00e6d0(0000) GS:ffffffff80758800(0000) knlGS:0000000000000000
CS:  0010 DS: 0000 ES: 0000 CR0: 000000008005003b
CR2: 0000000000000000 CR3: 000000000c296000 CR4: 00000000000006e0
Process mount (pid: 9457, threadinfo ffff810006700000, task ffff81001fd78790)
Stack: ffffffff8023328f 00000000fffffff4 00000000000000d0 0000000000000005 
       0000000000000000 0000000000000000 ffffffff80233666 0000000000000000 
       ffff810001ff0c80 ffffffff8060d820 
Call Trace:<ffffffff8023328f>{kobject_get_path+31} 
<ffffffff80233666>{do_kobject_uevent+54}
       <ffffffff8017f9c5>{kill_block_super+37} 
<ffffffff8017fb04>{deactivate_super+148}
       <ffffffff8017fe2e>{get_sb_bdev+302} 
<ffffffff801f0390>{isofs_fill_super+0}
       <ffffffff8017fba7>{do_kern_mount+103} <ffffffff801984c4>{do_mount+1860}
       <ffffffff8016700e>{__handle_mm_fault+1518} 
<ffffffff8015aa87>{get_page_from_freelist+743}
       <ffffffff802354f2>{__up_read+130} <ffffffff8015abe6>{__alloc_pages+118}
       <ffffffff8015ae77>{__get_free_pages+55} 
<ffffffff8019860b>{sys_mount+155}
       <ffffffff8010eb7a>{system_call+126} 

Code: 80 3f 00 74 14 48 89 f8 66 66 90 66 66 90 48 ff c0 80 38 00 
RIP <ffffffff80235a92>{strlen+2} RSP <ffff810006701c40>
CR2: 0000000000000000

The pc didn't seem to malfunction after this.

Helge Hafting

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: 2.6.15 OOPS while trying to mount cdrom
  2006-01-12 23:14 Chuck Ebbert
  2006-01-13  7:27 ` Helge Hafting
@ 2006-01-13  8:38 ` Andrew Morton
  1 sibling, 0 replies; 4+ messages in thread
From: Andrew Morton @ 2006-01-13  8:38 UTC (permalink / raw)
  To: Chuck Ebbert; +Cc: helgehaf, greg, linux-kernel, bzolnier

Chuck Ebbert <76306.1226@compuserve.com> wrote:
>
> In-Reply-To: <20060110184624.GA6721@aitel.hist.no>
> 
> On Tue, 10 Jan 2006 Helge Hafting wrote:
> 
> > Kernel 2.6.15 amd64, gcc 4.1.0 from debian.
> >
> > The cdrom (/dev/hda) is usually fine.  I tried booting with
> > hda=ide-scsi in order to read a scratched audio cd with cdparanoia.
> > That way, I at least get error messages when the scratches are
> > too bad.
> > 
> > I forgot about hda=ide-scsi, and tried to mount /dev/hda as
> > usual in order to read an ordinary iso9660 cd.  This is
> > probably not supposed to work when ide-scsi is using the device,
> > but then I expect something like EBUSY rather than this oops:
> > 
> > ide-scsi: unsup command: dev hda: flags = REQ_SORTED REQ_CMD REQ_STARTED 
> > REQ_ELVPRIV 
> > sector 64, nr/cnr 2/2
> > bio ffff8100044a9b40, biotail ffff8100044a9b40, buffer ffff81000cb4d000, data 
> > 0000000000000000, len 0
> > end_request: I/O error, dev hda, sector 64
> > isofs_fill_super: bread failed, dev=hda, iso_blknum=16, block=32
> > Unable to handle kernel NULL pointer dereference at 0000000000000000 RIP: 
> > <ffffffff80235a92>{strlen+2}
> 
> 
> The IDE driver probably shouldn't have allowed the bdev to be opened in
> the first place.
> 
> After that happened, mount attempted to fill the superblock and the I/O
> failed.  Upon failure, get_sb_bdev() called deactivate_super()
> (fs/super.c line 718) and all hell broke loose.
> 
>         - deactivate_super() called fs->kill_sb() (super.c line 176) which
>           pointed to kill_block_super() (fs/isofs/inode.c line 1411)
> 
>         - kill_block_super() called kobject_uevent() with action KOBJ_UMOUNT
>           (Question: why is it sending UMOUNT for a mount that never happened?)

Happily, all that code just got deleted:

    Also the new poll() interface to /proc/mounts is a nicer way to
    notify about changes than sending events through the core.
    The uevents should only be used for driver core related requests to
    userspace now.

I dunno how this removal works with forward- and backward- compatible
userspace.   Maybe it doesn't.

>         - kobject_uevent() called kobject_get_path() and one of the objects
>           had a null kobject.name, which caused strlen() to oops.


> There seem to be several bugs here:
> 
> (1) IDE shouldn't have allowed the bdev to be opened.

Maybe.  We've got in trouble in the past with making mounts try to get
exclusive access.  I can't immediately remember what the problem was.

> (2) (maybe) kobject_uevent shouldn't have been called for an unmount event
>     when the mount never succeeded.

Sounds reasonable.

> (3) kobject_get_path() shouldn't oops when a path component has a NULL name,
>     or else kobject should fail registration of any such object.

The printk in kobject_register() will oops if kobj->name is null, so yes,
it seems reasonable to make kobject_register() fail up-front if there's no
->name.   Greg agree?


Helge, it would be good if you could try the same trick on 2.6.15-git9 or
-git10, see if it behaves correctly.

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: 2.6.15 OOPS while trying to mount cdrom
  2006-01-12 23:14 Chuck Ebbert
@ 2006-01-13  7:27 ` Helge Hafting
  2006-01-13  8:38 ` Andrew Morton
  1 sibling, 0 replies; 4+ messages in thread
From: Helge Hafting @ 2006-01-13  7:27 UTC (permalink / raw)
  To: Chuck Ebbert
  Cc: Helge Hafting, Greg KH, linux-kernel, Bartlomiej Zolnierkiewicz

Chuck Ebbert wrote:

>In-Reply-To: <20060110184624.GA6721@aitel.hist.no>
>
>On Tue, 10 Jan 2006 Helge Hafting wrote:
>
>  
>
>>Kernel 2.6.15 amd64, gcc 4.1.0 from debian.
>>
>>The cdrom (/dev/hda) is usually fine.  I tried booting with
>>hda=ide-scsi in order to read a scratched audio cd with cdparanoia.
>>That way, I at least get error messages when the scratches are
>>too bad.
>>
>>I forgot about hda=ide-scsi, and tried to mount /dev/hda as
>>usual in order to read an ordinary iso9660 cd.  This is
>>probably not supposed to work when ide-scsi is using the device,
>>but then I expect something like EBUSY rather than this oops:
>>
>>ide-scsi: unsup command: dev hda: flags = REQ_SORTED REQ_CMD REQ_STARTED 
>>REQ_ELVPRIV 
>>sector 64, nr/cnr 2/2
>>bio ffff8100044a9b40, biotail ffff8100044a9b40, buffer ffff81000cb4d000, data 
>>0000000000000000, len 0
>>end_request: I/O error, dev hda, sector 64
>>isofs_fill_super: bread failed, dev=hda, iso_blknum=16, block=32
>>Unable to handle kernel NULL pointer dereference at 0000000000000000 RIP: 
>><ffffffff80235a92>{strlen+2}
>>    
>>
>
>
>The IDE driver probably shouldn't have allowed the bdev to be opened in
>the first place.
>
>After that happened, mount attempted to fill the superblock and the I/O
>failed.  Upon failure, get_sb_bdev() called deactivate_super()
>(fs/super.c line 718) and all hell broke loose.
>
>        - deactivate_super() called fs->kill_sb() (super.c line 176) which
>          pointed to kill_block_super() (fs/isofs/inode.c line 1411)
>
>        - kill_block_super() called kobject_uevent() with action KOBJ_UMOUNT
>          (Question: why is it sending UMOUNT for a mount that never happened?)
>
>        - kobject_uevent() called kobject_get_path() and one of the objects
>          had a null kobject.name, which caused strlen() to oops.
>
>There seem to be several bugs here:
>
>(1) IDE shouldn't have allowed the bdev to be opened.
>
>(2) (maybe) kobject_uevent shouldn't have been called for an unmount event
>    when the mount never succeeded.
>
>(3) kobject_get_path() shouldn't oops when a path component has a NULL name,
>    or else kobject should fail registration of any such object.
>
>
>  
>
>>The pc didn't seem to malfunction after this.
>>    
>>
>
>If you attempt to mount the CD a second time, mount will hang in D state; ps(1)
>reports it's at text.lock.super.  System cannot be cleanly shut down after that --
>shutdown(8) hangs and so does sync(1).
>  
>
Correct - much later I discovered that.  "sync" and another "mount"
hung in D-state, so I rebooted.  I am now running without ide-scsi
and have no problem using cd's. :-)

Helge Hafting

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: 2.6.15 OOPS while trying to mount cdrom
@ 2006-01-12 23:14 Chuck Ebbert
  2006-01-13  7:27 ` Helge Hafting
  2006-01-13  8:38 ` Andrew Morton
  0 siblings, 2 replies; 4+ messages in thread
From: Chuck Ebbert @ 2006-01-12 23:14 UTC (permalink / raw)
  To: Helge Hafting; +Cc: Greg KH, linux-kernel, Bartlomiej Zolnierkiewicz

In-Reply-To: <20060110184624.GA6721@aitel.hist.no>

On Tue, 10 Jan 2006 Helge Hafting wrote:

> Kernel 2.6.15 amd64, gcc 4.1.0 from debian.
>
> The cdrom (/dev/hda) is usually fine.  I tried booting with
> hda=ide-scsi in order to read a scratched audio cd with cdparanoia.
> That way, I at least get error messages when the scratches are
> too bad.
> 
> I forgot about hda=ide-scsi, and tried to mount /dev/hda as
> usual in order to read an ordinary iso9660 cd.  This is
> probably not supposed to work when ide-scsi is using the device,
> but then I expect something like EBUSY rather than this oops:
> 
> ide-scsi: unsup command: dev hda: flags = REQ_SORTED REQ_CMD REQ_STARTED 
> REQ_ELVPRIV 
> sector 64, nr/cnr 2/2
> bio ffff8100044a9b40, biotail ffff8100044a9b40, buffer ffff81000cb4d000, data 
> 0000000000000000, len 0
> end_request: I/O error, dev hda, sector 64
> isofs_fill_super: bread failed, dev=hda, iso_blknum=16, block=32
> Unable to handle kernel NULL pointer dereference at 0000000000000000 RIP: 
> <ffffffff80235a92>{strlen+2}


The IDE driver probably shouldn't have allowed the bdev to be opened in
the first place.

After that happened, mount attempted to fill the superblock and the I/O
failed.  Upon failure, get_sb_bdev() called deactivate_super()
(fs/super.c line 718) and all hell broke loose.

        - deactivate_super() called fs->kill_sb() (super.c line 176) which
          pointed to kill_block_super() (fs/isofs/inode.c line 1411)

        - kill_block_super() called kobject_uevent() with action KOBJ_UMOUNT
          (Question: why is it sending UMOUNT for a mount that never happened?)

        - kobject_uevent() called kobject_get_path() and one of the objects
          had a null kobject.name, which caused strlen() to oops.

There seem to be several bugs here:

(1) IDE shouldn't have allowed the bdev to be opened.

(2) (maybe) kobject_uevent shouldn't have been called for an unmount event
    when the mount never succeeded.

(3) kobject_get_path() shouldn't oops when a path component has a NULL name,
    or else kobject should fail registration of any such object.


> The pc didn't seem to malfunction after this.

If you attempt to mount the CD a second time, mount will hang in D state; ps(1)
reports it's at text.lock.super.  System cannot be cleanly shut down after that --
shutdown(8) hangs and so does sync(1).


-- 
Chuck
Currently reading: _Olympos_ by Dan Simmons

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2006-01-13  8:40 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2006-01-10 18:46 2.6.15 OOPS while trying to mount cdrom Helge Hafting
2006-01-12 23:14 Chuck Ebbert
2006-01-13  7:27 ` Helge Hafting
2006-01-13  8:38 ` Andrew Morton

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).