Message-Id: <201106020503.p5253cON017044@delorie.com> X-Recipient: archive-cygwin AT delorie DOT com X-SWARE-Spam-Status: No, hits=-2.3 required=5.0 tests=ALL_TRUSTED,AWL,BAYES_00,MISSING_MID X-Spam-Check-By: sourceware.org X-SWARE-Spam-Status: No, hits=-1.7 required=5.0 tests=AWL,BAYES_00,DKIM_SIGNED,DKIM_VALID,FREEMAIL_FROM,MISSING_MID,RCVD_IN_DNSWL_LOW,T_TO_NO_BRKTS_FREEMAIL From: Charles Wilson Date: Thu, 02 Jun 2011 00:18:48 -0400 Subject: [ANNOUNCEMENT] NEW: mingw-pthreads-20110507-1 To: cygwin AT cygwin DOT com Reply-To: cygwin AT cygwin DOT com Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner AT cygwin DOT com Mail-Followup-To: cygwin AT cygwin DOT com Delivered-To: mailing list cygwin AT cygwin DOT com The mingw-pthreads package provides Pthreads-W32, for use with the MinGW cross toolchain. Pthreads-W32 provides a POSIX-compliant pthreads implementation for the Win32 platform. The MinGW cross toolchain's libgomp library, which provides openmp support for that compiler, is linked against pthreadGC2.dll, as provided by this package. !!!!!!!!!!!!!!!!! !!!! WARNING !!!! !!!!!!!!!!!!!!!!! IF you are attempting to update an existing cygwin installation, which has the gcc-mingw 'add-on' packages installed (*), then you MUST upgrade the gcc-mingw packages to version 20050522-3 or newer, before installing this package. Do NOT attempt to upgrade gcc-mingw and install this package during the same setup.exe event. The reason for this restriction is fairly complex, and is detailed here: http://cygwin.com/ml/cygwin-announce/2011-04/msg00015.html If you are reading this announcement AFTER having messed up your cygwin installation, because you didn't follow these instructions or didn't know about them, then see the section in this message http://cygwin.com/ml/cygwin-announce/2011-04/msg00015.html that begins with "HELP!!!" and follow the suggestions there to "fix" it. (*) gcc-mingw packages are "add-ons" to the gcc-3 compiler suite, and provide the necessary files for the -mno-cygwin mode of that compiler. Ideally, this package and the accompanying i686-pc-mingw32 cross compiler will supplant the old 'gcc-3 -mno-cygwin' mode. ************ *** NOTE *** ************ If you have installed the "missing" mingw cross compiler packages from http://cygutils.fruitbat.org/ITP/mingw-gcc/ then you need take no special action. This package will simply upgrade the cygutils.fruitbat.org one. Two versions of Pthreads-W32 are supplied: 1. pthreadGC2.dll (C cleanup code) 2. pthreadGCE2.dll (C++ cleanup code) The first version is used by default. To use the GCE version, link with -lpthreadGCE2 rather than -lpthreadGC or -lpthread. Note that most platforms' pthread implementations, even when used with C++, follow the C cleanup model; that practice is also the recommended procedure in this case, with the MinGW cross compiler. To be perfectly clear: most users of the i686-pc-mingw32 cross compiler, if they desire to exploit pthreads functionality, should use -lpthread (which is the same as -lpthreadGC) regardless of language: C, C++, whatever. Furthermore, if you use the OpenMP (-fopenmp) features of GCC, then you must link against the "normal" pthreads library, because libgomp uses that version, and mixing the two versions is illadvised. Only those intrepid adventurers willing to brave the wilds of unusual, nay, wildly unpredictable, behavior should attempt to use the GCE (-lpthreadGCE) version -- and then, only if they are writing C++ programs. Read the pthreads-win32 documentation before experimenting with the C++ version. The non-standard DLL names are used to match the versions distributed by upstream Pthreads-W32. The DLLs are compiled using the same options as the upstream build (e.g. GC-inline, GCE-inline). There is a kernel mode driver that can be installed to (supposedly) improve the conformance of pthreadGCE2.dll (that is, the version which uses C++ cleanup code). That driver eventually will be available from MinGW.org, but for now may be found here: http://mingw.cwilson.fastmail.fm/ as QueueUserAPCEx-install.exe. This executable is a handy Inno-Setup installer for the i386, x86_64, and ia64 versions of the driver. However, it has a number of issues -- not least of which is that I have NOT found ANY conformance improvement with GCE *at all*! First, the 64bit bit drivers are completely untested. Second, Windows7 and Server2008 require all kernel mode drivers to be signed by a certified CA, at least in their 64bit incarnations (I'm not sure about the 32bit versions). I don't have a signed certicate with which to sign the driver -- and am not likely to ever get one. So, it's a good thing that even the GCE (C++ cleanup) version of libpthread works pretty well even without this driver -- and the GC (C cleanup) version doesn't need the driver at all, and achieves 100% compliance. So...that's why the version of Pthreads-W32 which uses C cleanup is used by default. For the curious, more information about the alertdrv.sys driver can be found at the following links: http://www.codeproject.com/KB/threads/queueuserapcex.aspx http://www.codeproject.com/KB/threads/QueueUserAPCEx_v2.aspx and the release notes accompanying QueueUserAPCEx-install.exe. -- Charles Wilson ==================================================================== To update your installation, click on the "Install Cygwin now" link on the http://cygwin.com/ web page. This downloads setup.exe to your system. Then, run setup and answer all of the questions. *** CYGWIN-ANNOUNCE UNSUBSCRIBE INFO *** If you want to unsubscribe from the cygwin-announce mailing list, look at the "List-Unsubscribe: " tag in the email header of this message. Send email to the address specified there. It will be in the format: cygwin-announce-unsubscribe-you=yourdomain DOT com AT cygwin DOT com If you need more information on unsubscribing, start reading here: http://sourceware.org/lists.html#unsubscribe-simple Please read *all* of the information on unsubscribing that is available starting at this URL. -- Problem reports: http://cygwin.com/problems.html FAQ: http://cygwin.com/faq/ Documentation: http://cygwin.com/docs.html Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple