From owner-freebsd-chat@FreeBSD.ORG Wed Oct 29 14:25:06 2003 Return-Path: Delivered-To: freebsd-chat@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 2D04E16A4CE for ; Wed, 29 Oct 2003 14:25:06 -0800 (PST) Received: from shell.webmaster.com (mail.webmaster.com [216.152.64.131]) by mx1.FreeBSD.org (Postfix) with ESMTP id 2944D43FDD for ; Wed, 29 Oct 2003 14:25:05 -0800 (PST) (envelope-from davids@webmaster.com) Received: from however ([206.171.168.138]) by shell.webmaster.com (Post.Office MTA v3.5.3 release 223 ID# 0-12345L500S10000V35) with SMTP id com; Wed, 29 Oct 2003 14:21:34 -0800 From: "David Schwartz" To: "Bill Moran" Date: Wed, 29 Oct 2003 14:24:58 -0800 Message-ID: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit X-Priority: 3 (Normal) X-MSMail-Priority: Normal X-Mailer: Microsoft Outlook IMO, Build 9.0.6604 (9.0.2911.0) In-Reply-To: <3FA00634.6000002@potentialtech.com> Importance: Normal X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2800.1106 cc: "Chat@Freebsd. Org" Subject: RE: How much better are 64 but platforms X-BeenThere: freebsd-chat@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Non technical items related to the community List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 29 Oct 2003 22:25:06 -0000 > I've never used FreeBSD on a 64 bit platform, and with a recent > project I've got > a client asking me, "How much faster would this run if we put it > on an Itanium." > > So, in the future, I'll probably be getting a 64 bit machine to > try this out on. > > But it got me thinking, what should I _expect_ to see in > improvement? This > application is mostly comparing strings, there are no 64 bit > integers or floats > to be obvious bottlenecks on a 32 bit platform, so (lacking > actual experience) > how much can I expect the application to speed up if I move it to a 64 bit > platform? Applications that primarily manipulate strings are not faster on 64-bit platforms and, in some cases, run more slowly. We suspect this is because, in relative terms, single byte accesses are more expensive. Applications that manipulate small integers (that fit in 32-bits) generally run at about the same speed. We do see slight slowdowns simply because of extra memory bandwidth being used due to 64-bits values taking twice as much space on the bus as 32. Applications that deal with large numbers (like cryptography) or bulk data (like compression) tend to get a boost. Database applications generally do get a performance boost because of the better ability to deal with large amounts of memory. In previous steps, 8-bit to 16-bit and 16-bit to 32-bit, quantities that previously had to be manipulated as multiple units could now be handled as a single unit. Most counters and integers exceed 8-bits, to moving to 16-bits halved the work for almost anything. Still, many such things didn't fit in 16-bits, so 32-bits halved the work for many things. However, almost everything fits in 32-bits. So 64-bits either gets no benefit for most things or just results in dragging extra bytes across the memory bus, which doesn't get any faster. However, we'll all need to smoothly handle more than 4Gb of memory real soon now. Memory mapping an 8Gb database may speed things up as well. It's too early for me to tell about these kinds of things yet. DS