From owner-freebsd-questions Sun May 2 18:17: 5 1999 Delivered-To: freebsd-questions@freebsd.org Received: from smtp03.primenet.com (smtp03.primenet.com [206.165.6.133]) by hub.freebsd.org (Postfix) with ESMTP id 9BF1514DC7; Sun, 2 May 1999 18:17:01 -0700 (PDT) (envelope-from tlambert@usr05.primenet.com) Received: (from daemon@localhost) by smtp03.primenet.com (8.8.8/8.8.8) id SAA24745; Sun, 2 May 1999 18:17:00 -0700 (MST) Received: from usr05.primenet.com(206.165.6.205) via SMTP by smtp03.primenet.com, id smtpd024702; Sun May 2 18:16:50 1999 Received: (from tlambert@localhost) by usr05.primenet.com (8.8.5/8.8.5) id SAA16700; Sun, 2 May 1999 18:16:49 -0700 (MST) From: Terry Lambert Message-Id: <199905030116.SAA16700@usr05.primenet.com> Subject: Re: Communicator 4.5: "Xlib: Unexpected async reply" msg flood! To: denis@acacia.cts.ucla.edu (Denis DeLaRoca) Date: Mon, 3 May 1999 01:16:49 +0000 (GMT) Cc: questions@FreeBSD.ORG, mozilla@FreeBSD.ORG In-Reply-To: from "Denis DeLaRoca" at Apr 30, 99 02:37:55 am X-Mailer: ELM [version 2.4 PL25] MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-freebsd-questions@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG > I've seen this problem occur with both the FreeBSD version of Communicator > 4.5 in the packages collection as well as with Communicator 4.51 for Linux > under FreeBSD 3.1. > > At some point, a popup appears with the following message, > > Bookmarks have changed on disk. > Discard your unsaved changes and reload > > OK CANCEL > > Most of the time clicking on Ok or CANCEL allows one to continue > normally... but at other times, Communicator starts looping and outputting > messages to stderr that read > > Xlib: Unexpected async reply (sequence 0x####) I believe the dialog box you refer to runs as JavaScript. There are a number of problems with the FreeBSD implementation of Netscape. The number one problem is that it is assuming that threads serially run to completion based on scheduling. Basically, this means that if you get an involuntary context switch, the threads pick up where they left off, in the order that they left off. The FreeBSD threads don't guarantee this (neither does POSIX), so the serialization assumption is flawed. For what it's worth, Linux and Macintosh threading have the same issues with the assumptions made by the NetScape JavaScript engine programmers. The major problems most commonly surface in the builtins, like the bookmark change script, the mail client, and the GIF decoder. The workaround for GIF's is to serialize the GIF loading (easy; just change your JavaScript) or to replace the GIF loader with a JNI to some reentrant code (not very easy, and not very portable; it'll only fix your personal browser). Since the problem exists on other platforms (e.g. Macintosh), it's best to just let it do its thing and finish doing it, before you move the mouse pointer. Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-questions" in the body of the message