58

This question is from 2012. If you are reading this in 2019 or later, then the answer really is: No. There is no good reason in 2019 to be maintaining 32-bit desktop operating systems.

Original question below:


Server software has been 64-bit only for a while now (Since Server 2008 R2 for Windows, even earlier for Exchange and Sharepoint) and even Ubuntu are pushing you away from 32-bit versions for their server OSes.

But is there any good, quantifiable reason to keep a 32-bit desktop operating system maintained? We're preparing our Windows 8 images for the (unfortunate?) few that will be early adopters.

The majority of our desktop computers have 4gb or less of RAM, but I would love to not have to bother supporting a 32-bit flavoured operating system any more.

Any reason why I should?

Mark Henderson
  • 68,316
  • 31
  • 175
  • 255

11 Answers11

58
  • 32-bit can be slightly faster in certain use cases -- the smaller addresses means sightly more compact code, which means greater cache efficiency. In the benchmarks I've seen, that efficiency tends to be be overshadowed by 64-bit's greater computational efficiency in heavy-computation environments. But 32-bit does in fact occasionally win on some benchmarks. YMMV. The age of your software matters, as newer builds take advantage of 64-bit stuff that older builds do not.

  • More compact code means less disk space. Just go download the ISOs for your favorite OS in 64 and 32 -bit flavors to see the difference. It's not trivial. It's also quite a lot more once you uncompress the binaries. As pointed out by OrangeDog: Much of this space consumption comes from the fact that 64-bit OSes ship 32-bit libraries in addition to the 64-bit ones.

  • You still get better compatibility with legacy components and software with 32-bit. This is particularly visible in systems that dynamically compile on the host machine but pull in 3rd-party binary libraries at the same time. Microsoft's .NET framework is a great example of this: while the programs are theoretically architecture-independent, anytime you link to a native binary you tie to one arch or the other. Many developers don't even know this is happening, and ship production components that will fail to run on 64-bit systems without some tweaking to explicitly instruct .NET to run in 32-bit mode. Most people don't know how to do this.

  • As pointed out by Daniel B: Windows .NET development on 64-bit machines leaves you open to a frustrating inconsistency where under certain circumstances exceptions are masked by the OS.

  • Legacy hardware. You can't run a 32-bit driver on a 64-bit kernel.

None of this adds up to a show-stopper for most people. Still, you have to decide how these factors affect your environment.

tylerl
  • 14,885
  • 7
  • 49
  • 71
  • 1
    The most complete answer so far. +1 – DejanLekic Sep 18 '12 at 08:20
  • 2
    Just FYI on performance. 64-bit code can be faster due to more registers, esp if doing a lot of integer work. – Macke Sep 18 '12 at 08:35
  • 17
    64-bit OS ISOs are bigger because they also contain the entirety of a 32-bit system in order to support both kinds of executable. The massive size difference is not because 64-bit binaries are bigger (they are, but not significantly). – OrangeDog Sep 18 '12 at 08:59
  • An interesting behavioural difference between 64-bit and 32-bit applications is [the way some exceptions can be silently swallowed](http://stackoverflow.com/questions/1583351/silent-failures-in-c-seemingly-unhandled-exceptions-that-does-not-crash-the-pr) in 64-bit environments, which would otherwise have bubbled up in 32-bit ones. Short example: if you have .Net code relying on a generic exception handler (Application.ThreadException), you will find that Form.Load swallows exceptions silently. – Daniel B Sep 18 '12 at 13:30
  • The above behaviour is not considered an issue by the Windows team (instead, the old implementation is considered wrong), so it's unlikely to be changed in future. I mention this specifically because it can be an issue, especially with in-house software, if the developers weren't aware of this behaviour. A lot of in-house software is thus "legacy and not 64-bit compatible" under this definition. – Daniel B Sep 18 '12 at 13:35
  • Upvoted for the mention of legacy hardware. The "compact code" point is honestly moot these days. – pauska Sep 18 '12 at 14:06
  • @OrangeDog very good point. I'll update accordingly. – tylerl Sep 18 '12 at 15:30
  • 64 bit programs generally also use more memory. – orlp Sep 18 '12 at 16:00
  • @nightcracker a 2x increase in used memory is not significant compared to a x^2 increase in addressable memory. – OrangeDog Sep 18 '12 at 16:49
  • 3
    @OrangeDog: that's comparing apples and oranges. _"Damn we have half the food, but at least the plate is big!"_ – orlp Sep 18 '12 at 16:56
  • @OrangeDog: Whether or not the issues with 64-bit are outweighed by the advantages, the purpose of the question was to simply identify the drawbacks so that the reader can draw his own conclusions. – tylerl Sep 18 '12 at 18:04
  • @nightcracker No, we have twice as much food, but don't worry as there's enough space on the plate to store enough food to feed the entire population of the planet many times over. – OrangeDog Sep 18 '12 at 18:11
  • @tylerl Indeed, but you can only do that if you actually compare them to the advantages. – OrangeDog Sep 18 '12 at 18:14
  • Correct me of I'm wrong but if we eventually adopt 64bit everywhere, the OS can (eventually) stop shipping with 32bit compatible binaries, and the size will go down again? (I know 100% adoption or even 90% adoption will take a LONG time) – Aren B Sep 18 '12 at 19:46
  • @ArenB It takes a while for legacy software to die out, but it happens. There's not a lot of 16-bit software still kicking around, but you'll find it every now and then. (Did you know we did this once before with the 16 to 32-bit switch almost 20 years ago?) – tylerl Sep 18 '12 at 19:52
  • @tylerl: I know, that's why I brought it up. I guess the question was partially rhetorical. I was suggesting that the refusal to move forward only makes the bloat take longer to go away. I was also looking for a bit of confirmation because the 16->32 bit shift happened when I was 7-10 :) – Aren B Sep 19 '12 at 00:25
  • @OrangeDog The size difference is still there if you exclude the compatibility thing. For instance, Arch Linux 64bit doesn't ship with 32-bit compatibility libraries. The size difference is that 64bit version is about 30M larger.. – Earlz Sep 19 '12 at 01:46
  • 1
    @Earlz http://archlinux.mirrors.uk2.net/iso/2012.09.07/arch/ looks like only 3M larger to me – OrangeDog Sep 19 '12 at 09:11
  • Er, why was my comment deleted? It was correct - there is no issue running 32-bit .Net code on 64-bit Windows, unless the assembly is loaded manually in code *(which is extremely rare)*. The largest bullet-point is incorrect. – BlueRaja Sep 20 '12 at 06:50
  • @BlueRaja Looks like several were deleted. No, the bullet is not incorrect, and you said so yourself, you just said it was rare. There are several cases where code that loads a 32-bit lib will JIT to 64. Manual assembly loading is one of them. They're uncommon enough that programmers don't know to even look for them, so they show up in production. – tylerl Sep 20 '12 at 07:20
  • Your link on the text "frustrating inconsistency" is broken – Ferrybig Jan 16 '19 at 10:09
29

The only reason I can think of to keep a 32-bit desktop operating system is if you use old 16 bit (e.g. DOS) programs and you do not have the windows version which supports Windows Virtual PC.

(And even then I would install a 64 bit OS and use something like DOSbox).

Edit: There actually is another reason: Hardware which fails to cope with more than 4GB address space. E.g. FireWire trying to do DMA. Or any (old) hardware with no 64 bit drivers.

Hennes
  • 4,772
  • 1
  • 18
  • 29
  • Actually this is a very valid reason for keeping 32-bit around. I'd forgotten about this. Thankfully I don't think we have any 16-bit software left ;) – Mark Henderson Sep 18 '12 at 00:35
  • 3
    But there's free software to do that, so it's not really a good reason, is it? – naught101 Sep 18 '12 at 06:23
  • 3
    Non just MS-DOS based applications, also potentially Win16-based applications . – Alan B Sep 18 '12 at 08:26
  • @Naught101: Yes, there is free software for DOS. And for windows there is always Vmware player, Oracle virtual box, windows virtual PC, wine for windows (assuming it works without 16 bit stuff) etc etc. Alan: 1) Indeed, though I haven't seen any old win16 programs in ages. Maybe I am lucky though. :) 2) Yes, hence the example gratia DOS. – Hennes Sep 18 '12 at 12:46
  • I take it you haven't tried to use a 64 bit Windows on 2GB of RAM. – joshudson Jan 16 '19 at 18:38
  • 2GB? My 2009 laptop (a dell E6500) has more. And that is the older piece of equipment still sensibly in use, now 9 years and 8 days old. Except for phones and tablets and similar 2GiB is a thing from the deep past. – Hennes Jan 17 '19 at 19:39
17

Anything that will run Windows 8 is already 64-bit capable, unless you happen to have some first-generation Intel Atom netbooks (and I doubt that very much). That's about the only thing I can think of.

AMD released its first 64-bit capable Opteron in 2003; and since then virtually every processor they have made has been 64-bit capable.

Intel was a year later, releasing its first 64-bit Xeon (Nocona) in 2004, and expanding to just about the entire product line by 2006. Aside from the aforementioned early Atom chips, every Intel processor today is 64-bit.

Wikipedia has a broken down processor list if you're interested in ancient history.

Michael Hampton
  • 237,123
  • 42
  • 477
  • 940
  • Actually I think we do have a HP Mini 1st generation Atom, but it's still on XP and is way back in the "only touch if I have to" pile, so it's a bit of a non-issue. – Mark Henderson Sep 18 '12 at 00:29
  • 2
    And 64-bit XP was such a nightmare that nobody ever ran it anyway. No problem there. – Michael Hampton Sep 18 '12 at 00:31
  • 1
    I ran XPx64. It wasn't that bad. It just wasn't XP. If they'd called it what it actually was (Server 2003, lite edition) it probably wouldn't have been such a nightmare. – HopelessN00b Sep 18 '12 at 02:52
  • Do not forget the first-generation Intel Core CPUs that were NOT 64-bit capable: http://en.wikipedia.org/wiki/List_of_Intel_Core_microprocessors. I found out the hard way... – priestjim Nov 29 '12 at 15:37
7

Compatibility with Ancient Software/Hardware.

If everything works under x64, I wouldn't bother with 32 bit.

bbezaire
  • 175
  • 6
  • I guess this is a more of a "What doesn't work under 64-bit" question... – Mark Henderson Sep 18 '12 at 00:37
  • 2
    Printer drivers especially. "Standard paths" for programs become complicated when you have a mix of "Program Files" and "Program Files (x86)" too. – Andrew Sep 18 '12 at 01:52
4

Memory addresses in a 64 bit machine naturally take 64 bits. Those same addresses take 32 bits in a 32 bit machine. Under some pretty exceptional circumstances, that "increase" in needed number of bits can be the difference between good performance and poor performance on a memory limited machine.

Beyond that, since you are likely to be running 32 bit software on a machine that could be running 64 bit software anyway, and 32 bit support works reasonably well on 64 bit machines, the differences on the hardware side are not game changing. Occasionally you will find a legacy device that doesn't have a 64 bit hardware driver, but that is now very rare due to 64 bit operating systems being available for over a decade.

One point to consider is that many older 32 bit applications are older in many ways beyond their bit-ness. On the windows OS side, a 32 bit app might get confused if it is looking for files in "Program Files" that are now located in "Program Files (x86)". Certain registry items likewise might need manual attention. Again this is more a function of slightly mis-written applications that now need your help to "find" things that would have "just worked" if the machine happened to be 32 bit.

Edwin Buck
  • 257
  • 1
  • 4
4

Many people don't know that 64-bit programs and libraries occupy more memory than 32-bit equivalents.

For example, when using low-memory virtual machines, it is advisable to use 32-bit operating systems to maximize memory availability inside that VM.

Giovanni Toraldo
  • 2,557
  • 18
  • 27
3

Speaking of Ubuntu, we have been running 64-bit 12.04 LTS under LTSP for a few weeks now.

The only hassle we've run into for the initial beta testers is that the LTSP terminals we use (Dell GX2xx) require a 32-bit kernel and thus we have to compile a 2nd LTSP kernel and maintain twice as many packages for the two architectures.

LTSP being QUITE an edge case, I think 64-bit is fairly ready to go unless your particular testing shows a defect.

Magellan
  • 4,431
  • 3
  • 29
  • 53
2

Although I'd personally recommend moving to 64-bit as soon as possible and just bite the bullet sooner rather than later, it won't be without impact to your IT support team. If the support team's bandwidth is already stretched to a maximum (i.e., already understaffed), then I'd actually consider waiting.

So, this is one answer that concerns human resources, not just software in/compatibility.

The roll-out should be of course carefully planned (preferably gradual rather than all-at-once). There are going to be issues "discovered" that will take hours to resolve on a per-user basis. Once the more common issues are identified, "how-to's" can guide faster resolutions for both support calls as well as self-service.

Mostly, (for example), I'm thinking of all the 32 and 64 bit (in)compatibility issues between the OS, a specific software package and the associated plugins, such as having both 32-bit and 64-bit browsers installed (and/or multiple browsers) on a single 64-bit OS, shortcuts for 'run as admin' vs 'run as normal user', having options for both a 32 and 64-bit plugin for those browsers (or sometimes maybe restricted to only 32-bit plugins which only work in one version of the browser) -- all that break applications and workflows built on top of those plugins. (By "plugins" I mean anything from Java to flash to embedded pdf readers to web conferencing software -- either built in-house or widely available, both commercial and free.) You can attempt to test for all of these issues, but it's hard to predict if a user will inadvertently install plugin B before plugin A, which causes a different result than another user who installs plugin A before plugin B (basically it's always hard to predict what damage users will do when their actions change the state of the system.)

michael
  • 384
  • 1
  • 5
1

The only reason to keep 32 bit versions of... anything... around is to support "legacy" applications and systems. If you can run everything on 64 bit OSes, count yourself lucky and move on. You could be like some poor SAs who are in a corporate environment for a non tech firm, where the plan for migrating from the user base from XP to Windows 7 starts in the thrid quarter of 2014.

<cries>

Anyway, I don't know about Shift+Del, and I'd probably just leave them ignored in some corner of the environment, in case the unspeakable happens and you find yourself needing Windows XP for something. Definitely stop bothering to maintain, update, test or anthing else on them, but keep them around should they ever be needed. It happened the other day that a client wanted me to support some Windows 2000 PoS, which I could, because I didn't blow away all my Server 2000 images when Server 2003 came out (and I really wanted to, too).

As much as you pray and hope that time never comes, it's always nice to have that stuff around "just in case," and the costs of keeping it are so insignificantly small, I think it's foolish not to.

HopelessN00b
  • 53,385
  • 32
  • 133
  • 208
1

Having had considerable problems due to legacy software issues I can only say to make sure everything you run can be run on a 64 bit OS. If it does then you have no reason not to migrate, assuming licensing isn't a factor.

In my case I was able to reconfigure systems so that all 32bit only applications were able to run on the one machine, allowing all the other workstations to be 64 bit. Eventually I even migrated that 32 bit machine to a VM on Virtualbox, running on a Debian host, mainly because the capacity was there and I wanted to reduce the box count.

John Gardeniers
  • 27,262
  • 12
  • 53
  • 108
-4

All of the above and several virtual machines cannot run x64-bit code if the CPU doesn't support virtualization (e.g. VT-x feature).

Several cheaper 64-bit CPUs which lack VT-x, etc are however attractive for 'homemade' clusters.

From wikipedia:

Intel did not add segmentation support to its x86-64 implementation (Intel 64), making 64-bit software-only virtualization impossible on Intel CPUs, but Intel VT-x support makes 64-bit hardware assisted virtualization possible on the Intel platform

  • 1
    -1 Only if the virtualization technology **requires VT-x**... Not all do. Beside that point, your "Answer" is little more than a comment on what *might not work*. That's not very helpful nor really qualifies as an Answer. – Chris S Sep 18 '12 at 14:58