Re: [PATCH] Correctly flush 8250 buffers, notify ldisc of linestatus changes.

From: Andrew Morton
Date: Tue Nov 09 2004 - 04:24:28 EST


David Woodhouse <dwmw2@xxxxxxxxxxxxx> wrote:
>
> We weren't flushing the TX FIFO on 8250 uarts when uart_flush_buffer()
> was called. This adds a flush_buffer() method to the uart_port
> operations and calls it from uart_flush_buffer().

Your patch makes my computer stop working, which saddens me.


NMI Watchdog detected LOCKUP on CPU1CPU 1
Modules linked in:
Pid: 1, comm: init Not tainted 2.6.10-rc1-mm4
RIP: 0010:[<ffffffff803b04c0>] <ffffffff803b04c0>{_spin_lock_irqsave+31}
RSP: 0018:ffff81007ff19d68 EFLAGS: 00000013
RAX: 0000000000000000 RBX: 0000000000000000 RCX: 0000000000000000
RDX: 0000000000000001 RSI: 0000000000000000 RDI: 0000000000000001
RBP: ffffffff80585da0 R08: ffff81000b663920 R09: 0000000000000000
R10: ffff81017ffa3980 R11: 0000000000000040 R12: 0000000000000246
R13: ffff81017f4de000 R14: ffff81000b65ad28 R15: 0000000000000000
FS: 0000000000000000(0000) GS:ffffffff80594c80(0000) knlGS:0000000000000000
CS: 0010 DS: 0000 ES: 0000 CR0: 000000008005003b
CR2: 0000000000000000 CR3: 000000017f4e6000 CR4: 00000000000006e0
Process init (pid: 1, threadinfo ffff81007ff18000, task ffff81007ffaf740)
Stack: 0000000000000013 ffffffff80585da0 ffffffff80585da0 ffffffff8028fe34
0000000000000246 ffff81000b65ad08 0000000000000246 ffffffff8028d8d3
ffffffff80585da0 0000000000000246
Call Trace:<ffffffff8028fe34>{serial8250_flush_buffer+15} <ffffffff8028d8d3>{uart_flush_buffer+75}
<ffffffff8028e9bc>{uart_close+332} <ffffffff80272fa9>{release_dev+578}
<ffffffff8017b942>{chrdev_open+438} <ffffffff8015ae42>{poison_obj+56}
<ffffffff80174273>{filp_dtor+0} <ffffffff802737a2>{tty_release+17}
<ffffffff8017406d>{__fput+100} <ffffffff80171911>{filp_close+107}
<ffffffff8017199c>{sys_close+132} <ffffffff8010f346>{system_call+126}


Maybe the lock which uart_flush_buffer() takes is the same as the lock
which serial8250_flush_buffer() takes?
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/