From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1MgXAb-0004p8-I2 for qemu-devel@nongnu.org; Thu, 27 Aug 2009 01:05:09 -0400 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1MgXAW-0004np-Du for qemu-devel@nongnu.org; Thu, 27 Aug 2009 01:05:08 -0400 Received: from [199.232.76.173] (port=47715 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1MgXAW-0004nj-Al for qemu-devel@nongnu.org; Thu, 27 Aug 2009 01:05:04 -0400 Received: from bilbo.ozlabs.org ([203.10.76.25]:51337) by monty-python.gnu.org with esmtps (TLS-1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.60) (envelope-from ) id 1MgXAU-0004O8-A5 for qemu-devel@nongnu.org; Thu, 27 Aug 2009 01:05:03 -0400 From: Michael Ellerman In-Reply-To: <20090826154552.GA31910@amit-x200.redhat.com> References: <1251181044-3696-1-git-send-email-amit.shah@redhat.com> <20090826112718.GA11117@amit-x200.redhat.com> <20090826154552.GA31910@amit-x200.redhat.com> Content-Type: multipart/signed; micalg="pgp-sha1"; protocol="application/pgp-signature"; boundary="=-zDgknRdlrvhso4zVsYgt" Date: Thu, 27 Aug 2009 15:04:45 +1000 Message-Id: <1251349485.6267.6.camel@concordia> Mime-Version: 1.0 Subject: [Qemu-devel] Re: Extending virtio_console to support multiple ports Reply-To: michael@ellerman.id.au List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Amit Shah Cc: Ryan Arnold , kvm@vger.kernel.org, linuxppc-dev@ozlabs.org, linux-kernel@vger.kernel.org, miltonm@bga.com, qemu-devel@nongnu.org, borntraeger@de.ibm.com, brueckner@linux.vnet.ibm.com, virtualization@lists.linux-foundation.org, alan@linux.intel.com --=-zDgknRdlrvhso4zVsYgt Content-Type: text/plain Content-Transfer-Encoding: quoted-printable On Wed, 2009-08-26 at 21:15 +0530, Amit Shah wrote: > [cc'ing some people who have made some commits in hvc_console.c] >=20 > On (Wed) Aug 26 2009 [16:57:18], Amit Shah wrote: > > On (Tue) Aug 25 2009 [11:47:20], Amit Shah wrote: > > >=20 > > > Hello all, > > >=20 > > > Here is a new iteration of the patch series that implements a > > > transport for guest and host communications. > > >=20 > > > The code has been updated to reuse the virtio-console device instead > > > of creating a new virtio-serial device. > >=20 > > And the problem now is that hvc calls the put_chars function with > > spinlocks held and we now allocate pages in send_buf(), called from > > put_chars. > >=20 > > A few solutions: >=20 > [snip] >=20 > > - Convert hvc's usage of spinlocks to mutexes. I've no idea how this > > will play out; I'm no expert here. But I did try doing this and so fa= r > > it all looks OK. No lockups, lockdep warnings, nothing. I have full > > debugging enabled. But this doesn't mean it's right. >=20 > So just to test this further I added the capability to have more than > one hvc console spawn from virtio_console, created two consoles and did > a 'cat' of a file in each of the virtio-consoles. It's been running for > half an hour now without any badness. No spew in debug logs too. >=20 > I also checked the code in hvc_console.c that takes the spin_locks. > Nothing there that runs from (or needs to run from) interrupt context. > So the change to mutexes does seem reasonable. Also, the spinlock code > was added really long back -- git blame shows Linus' first git commit > introduced them in the git history, so it's pure legacy baggage. I won't tell Ryan you called his code "pure legacy baggage" if you don't ;) http://git.kernel.org/?p=3Dlinux/kernel/git/torvalds/old-2.6-bkcvs.git;a=3D= commitdiff;h=3Dd450b4ae023fb4be175389c18f4f87677da03020 cheers --=-zDgknRdlrvhso4zVsYgt Content-Type: application/pgp-signature; name="signature.asc" Content-Description: This is a digitally signed message part -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.9 (GNU/Linux) iEYEABECAAYFAkqWE+oACgkQdSjSd0sB4dJ77QCglGJ1hqEa1QKiDnJYj5Wd7qZ3 BZgAoIKPSyPRRk69t+vlctG7SDLv/SSX =lH9C -----END PGP SIGNATURE----- --=-zDgknRdlrvhso4zVsYgt--