Commit d45eb81c authored by Denis Joseph Barrow's avatar Denis Joseph Barrow Committed by Linus Torvalds
Browse files

tty: Fix double grabbing of a spinlock



The HSO changes for kref introduced a recursive spinlock take. All
functions which call put_rxbuf_data already have serial->serial_lock
grabbed.

[Comment to code added-AC]

Signed-off-by: default avatarDenis Joseph Barrow <D.Barrow@option.com>
Signed-off-by: default avatarAlan Cox <alan@redhat.com>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent fe41cbb1
Loading
Loading
Loading
Loading
+1 −2
Original line number Diff line number Diff line
@@ -2044,9 +2044,8 @@ static int put_rxbuf_data(struct urb *urb, struct hso_serial *serial)
		return -2;
	}

	spin_lock(&serial->serial_lock);
	/* All callers to put_rxbuf_data hold serial_lock */
	tty = tty_kref_get(serial->tty);
	spin_unlock(&serial->serial_lock);

	/* Push data to tty */
	if (tty) {