tty: mark Siemens R3964 line discipline as BROKEN
commite0d2ad5eaec135bb79a7045b1c0718557bac4c4d
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 5 Apr 2019 13:39:26 +0000 (5 15:39 +0200)
committerBen Hutchings <ben@decadent.org.uk>
Thu, 2 May 2019 20:42:07 +0000 (2 21:42 +0100)
treefeebf80039b172487a98a95632a993ab6effe228
parenta62ea6707949c2a49f8a4f62c5b5d4c1703451d3
tty: mark Siemens R3964 line discipline as BROKEN

commit c7084edc3f6d67750f50d4183134c4fb5712a5c8 upstream.

The n_r3964 line discipline driver was written in a different time, when
SMP machines were rare, and users were trusted to do the right thing.
Since then, the world has moved on but not this code, it has stayed
rooted in the past with its lovely hand-crafted list structures and
loads of "interesting" race conditions all over the place.

After attempting to clean up most of the issues, I just gave up and am
now marking the driver as BROKEN so that hopefully someone who has this
hardware will show up out of the woodwork (I know you are out there!)
and will help with debugging a raft of changes that I had laying around
for the code, but was too afraid to commit as odds are they would break
things.

Many thanks to Jann and Linus for pointing out the initial problems in
this codebase, as well as many reviews of my attempts to fix the issues.
It was a case of whack-a-mole, and as you can see, the mole won.

Reported-by: Jann Horn <jannh@google.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
drivers/char/Kconfig