Pay no attention to the processor in the box

Last week, Apple made waves when it announced that future Macintosh models, beginning next year, will contain Intel processors just like other PCs. Some people have asked me what I think about this, so here goes:


The transition to Intel is going to be a great thing.


Now, before I continue: I really don’t much care for the Intel architecture. I am a True Believer in the RISC approach embodied in the PowerPC architecture. However, for reasons that should become clear as I continue, for most intents and purposes, the processor doesn’t matter.


the “new” technology



I started off working life as a NeXTStep developer. For those who don’t know, NeXTStep was a product of Steve Jobs’ other computer company, NeXT, the one he created during the “dark years” (ca 1985-1997) that he wasn’t with Apple. NeXT was a financial failure, but they created some great technology, both hardware and software. The software, in the form of the NeXTStep operating system and development environment, makes up the underpinnings of Mac OS X. I have always held the opinion that Mac OS X could more accurately be called “NeXTStep 5.0”.

Anyway, back in the early 90’s, NeXTStep ran only on NeXT’s own hardware, great beastly black boxes with Motorola 680×0 processors. The hardware was technologically similar to top-of-the-line Macs of that era, but typically with much larger screens, larger hard disks, more RAM, and a much higher price tag. In 1993, NeXT announced that they were getting out of the hardware business entirely, and were going to focus on the NeXTStep operating system, which they had secretly ported to… Intel! Does this sound familiar to anyone?


So what was a developer to do? Well, in most cases, they could simply compile their software for Intel by clicking a single checkbox in the NeXTStep IDE. The compiler would then compile the code for both platforms, and bundle them together into what could have been called a “universal binary” (again, does this sound familiar?). This would then run on both Motorola-based NeXT machines and Intel-based PCs.


Not content to stop there, NeXT also ported their operation system to run on Sun SPARC workstations and HP HP-RISC workstations. And as a developer, all you had to do was click on the checkboxes to enable those platforms, and off you went!


But could it really be that easy? Well, in a word: YES. If you didn’t do much low-level bit-flipping, it really was pretty much that easy. So much so that freeware developers routinely released “quad-fat applications” that ran on all four platforms, even if they never had access to one or more of the target platforms for testing. They’d just put it out there, say “email me if it doesn’t work right on your machine”, and call it a day.


Of course, there are applications that require low-level bit-flipping, but that can usually be done with per-platform compiler macros and what have you, so you can abstract that away and off you go.


So, we jump forward twelve years in time and arrive at last week. Apple announces technology that old NeXT nerds like me have always known they’ve had, and that we know works. Hell, even people who’ve been Apple nerds since 1997 or 1998 or so should remember that the early, pre-release “Rhapsody” versions of Mac OS X ran both on old Apple G3s and Intel PCs. So really, the technology is not new and has been obviously under the covers ever since Apple acquired NeXT, who nailed this a decade ago.


[
But of course, it wasn’t called that. It was called a “fat binary”. No one ever accused NeXT of being especially good at marketing.

hardware orphans



One concern I’ve heard thrown about is that PPC hardware will be “orphaned”. Although this will surely happen at some point, it’s still years away; everyone using current hardware will be able to use it several years into the future. Look at it this way:


I believe that 5 years is a pretty good amount of time for people to think about buying some new hardware, so I really don’t think this is going to be too painful.


The only real scenarios I can see being problematic are where people are running specific PCI hardware such as for high-end audio/video applications; If your manufacturer can’t or won’t create new drivers for MacIntel (if they’ve stopped caring about their Mac products, or have gone out of business, or whatever), you’ll probably have to buy new extra hardware for your special needs when you switch to MacIntel. But in five years time, you’d probably want to replace it anyway, since considering the march of progress, today’s “top-of-the-line” audio gear is tomorrow’s “free-with-your-subscription-to-PC-user-magazine” throwaway kit, so hey.

Comments