From owner-cvs-ports@FreeBSD.ORG Sat Oct 16 17:12:23 2004 Return-Path: Delivered-To: cvs-ports@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 06A9516A4CE; Sat, 16 Oct 2004 17:12:23 +0000 (GMT) Received: from repoman.freebsd.org (repoman.freebsd.org [216.136.204.115]) by mx1.FreeBSD.org (Postfix) with ESMTP id EF5DA43D2D; Sat, 16 Oct 2004 17:12:22 +0000 (GMT) (envelope-from glewis@FreeBSD.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.12.11/8.12.11) with ESMTP id i9GHCMuF022183; Sat, 16 Oct 2004 17:12:22 GMT (envelope-from glewis@repoman.freebsd.org) Received: (from glewis@localhost) by repoman.freebsd.org (8.12.11/8.12.11/Submit) id i9GHCMaX022182; Sat, 16 Oct 2004 17:12:22 GMT (envelope-from glewis) Message-Id: <200410161712.i9GHCMaX022182@repoman.freebsd.org> From: Greg Lewis Date: Sat, 16 Oct 2004 17:12:22 +0000 (UTC) To: ports-committers@FreeBSD.org, cvs-ports@FreeBSD.org, cvs-all@FreeBSD.org X-FreeBSD-CVS-Branch: HEAD Subject: cvs commit: ports/java/jdk14/files patch-interpreter_shared.hpp X-BeenThere: cvs-ports@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: CVS commit messages for the ports tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 16 Oct 2004 17:12:23 -0000 glewis 2004-10-16 17:12:22 UTC FreeBSD ports repository Added files: java/jdk14/files patch-interpreter_shared.hpp Log: . Fix the Server VM for gcc 3.4 part 1/2. The HotSpot code (ab)uses named enums as ints in a number of places. The problem with this is that according the the C++ spec, the compiler (essentially) only needs to use an integral type wide enough to hold the values defined in the enum. Earlier versions of gcc appear to have just used an int whether they could have got away with a narrower type or not, hence the code worked as expected. gcc 3.4 now appears to implement this part of the spec, so using an enum blindly as an int causes various problems due to overflow. This case is particularly bogus since the enums are merely to define a named integral type within a class (VMReg::Name doesn't even have any values enumerated in the declaration). So, convert these two enums to simply be typedef'ed ints. Sleuth work, discussion and code suggestions: peadar Revision Changes Path 1.1 +38 -0 ports/java/jdk14/files/patch-interpreter_shared.hpp (new)