x86-S: Intel wants to drop legacy compatibility from processors

The long-awaited clean-up of the decades-old x86 architecture finally approaching?

The scenario of Intel dropping backwards compatibility and creating a new version of x86 processors free of various “legacy burdens” has been discussed for a long time. The hype around ARM processors and the perceived or real advantages they gain by not carrying similar “baggage” highlighted this topic again. Intel has unveiled a proposal for a simplified pure 64-bit x86-S architecture that could bring about such a revolution, now.

Intel has now released documents proposing an architecture called x86-S, which is a planned future revision of the x86 instruction set and processor platform, currently still in the draft phase. So it isn’t necessarily anything definitive for now. The S designation should mean “simplified”. Thus, it is not an entirely new instruction set, but it adds some changes to the existing x86-64 that will break decades of compatibility.

The x86-S architecture should be 64-bit only, or at least partially so. Today’s x86 processors are 64-bit, but they retain full compatibility with not only 32-bit but also 16-bit mode. They boot (reset) in 16-bit mode and only then does the firmware switch to 64-bit, during firmware initialization. This would be removed by the x86-S architecture, the processors would always natively work only in 64-bit mode.

It would not, however, mean a complete elimination of 32-bit compatibility, as ARM processor manufacturers have done. Chips based on the x86-S architecture would no longer be able to run a native 32-bit operating system, but support for running 32-bit software in user space mode on top of a 64-bit operating system would remain. The gist is that the Ring 0 privilege level would no longer be available for 32-bit mode.

Simplified CPU booting directly in 64-bit mode (source: Intel)

However, compatibility with legacy 32-bit OSes (such as Windows XP or even older systems) should be possible to attain through virtualization. So a 32-bit OS would not work directly on hardware, but it should be able to run with a suitable hypervisor that handles the incompatibility of x86-S with the original x86 platform.

However, from what Intel says, 64-bit operating systems will have to be modified as well, so new versions of Windows and Linux will probably be needed for the x86-S. Virtualization should help in this case too and allow usage of older 64-bit OSes. Conversely, the ability to run any 16-bit code (not just kernel but user space too) natively on the baremetal hardware will be completely lost. Such applications will therefore have to be emulated on x86-S.

These changes will help to simplify the processor design a bit and save some transistors and perhaps even some power consumption, too. It probably won’t bring a huge amount of savings, but it will simplify the validation (verifying that the CPU is working correctly), which is a time consuming and very hard part of processor development. It will also eliminate some of the bugs that can be introduced into these more obscure parts of CPUs. Intel notes that these legacy modes and functionality tend to be used very little in practice outside of that short usage during boot time.

Along with 16-bit and 32-bit mode, Intel proposes to drop several other features. For example, Ring 1 and Ring 2 privilege levels (which are mostly unused by modern software) and access to I/O ports from user space (Ring 3) are to be removes. The latter would mean that some software would have to be rewritten to use MMIO. There are also proposed changes to interrupt handling. With the changes proposed for he x86-S architecture, it would also be possible to switch between a four-level and five-level page tables without the need to switch CPU to unpaged mode (which is now a required intermediate step).

Proposed changes in the x86-S architecture (source: Intel)

When various analysts or commenters considered the eventual redesign of the x86 processor platform in the past, it was often assumed that Intel could remove support for, for example, MMX and x87 instructions (and their registers), which would also simplify the processor design. But this would stop a large number of compiled applications from working at the user space level, not just at the OS (kernel) level. The x86-S design does not seem to include anything like this so far. It looks like pure userspace software might not be affected much, and thus there might not be that many broken legacy programs.

Historic x86 processors from AMD and Intel (photo: Cnews)

The proposed changes look quite a bit less radical than what ARM has done with the ARMv8 and ARMv9 architectures, which also started out by only allowing 32-bit software to run only in user space (while no longer supporting 32-bit kernel/OS) followed by abandoning any 32-bit backwards compatibility entirely. However, ARM’s 64-bit instruction set is a new (from the grounds up designed) ISA completely separated from the 32-bit one. The x86 architecture (courtesy of AMD) has implemented the 64-bit ISA as an extension of the 32-bit mode on the other hand, so cutting deeper into x86 legacy would create far-reaching incompatibilities with existing 64-bit software.

In any case, this proposal is probably still open for discussion and Intel wants to get some feedback and suggestions from users, among other things. Thus, the final version of the “legacy-free” x86 architecture may end up differing in various ways as well.

Sources: Tom’s Hardware, Intel (1, 2)

English translation and edit by Jozef Dudáš


  •  
  •  
  •  
Flattr this!

Intel cancels x86S, effort to clean up x86 CPUs legacy cruft

In fall, we reported here that Intel’s Panther Cove CPU architecture coming in two years (not in Panther Lake CPUs though) reportedly adopts an upgrade to the x86 instruction set labeled APX and also the AVX10 SIMD instructions, which are a compromise between AVX-512 and AVX2 designed for hybrid processors. However, the x86S architecture, the third of these awaited ISA innovations, will not be coming. It has in fact been cancelled. Read more “Intel cancels x86S, effort to clean up x86 CPUs legacy cruft” »

  •  
  •  
  •  

APX and AVX10 in two years? Intel to introduce them in Nova Lake

Last year, Intel unveiled plans for improving the x86 platform and instruction set, on which virtually all PC CPUs (from Intel, AMD, China’s Zhaoxin) are based: The APX extension, which breaks through the limitations in the number of registers (somewhat mitigating ARM’s advantage), and AVX10, which is the successor or evolution of AVX-512. For a long time it was unclear when these innovations would ship, but now we finally know. Read more “APX and AVX10 in two years? Intel to introduce them in Nova Lake” »

  •  
  •  
  •  

Zen 5: AMD’s biggest innovation since first Zen [expanded deep dive]

It’s roughly two weeks until AMD releases processors with the new Zen 5 architecture. This week, we finally got proper details on these CPUs’ architecture, which AMD revealed at the Tech Day event. So, we can now break down the changes the company has made to the core, compared to Zen 4 – and they’re pretty extensive, probably more so than they seemed in June. And AMD also reiterated its promise of a 16% increase in IPC for these CPUs. Read more “Zen 5: AMD’s biggest innovation since first Zen [expanded deep dive]” »

  •  
  •  
  •  

Comments (2) Add comment

  1. I remember reading about the possibility of removal of some specialized blocks and translating these instructions to AVX to save some space, though it’s possible that either the translator would be big enough to not bring any savings or the savings are not (yet) worth the effort

    what I’d like to know is: will x86-S software run on x88-64 hardware? looks like the OS would likely need some tweaks in the booting process at the very least, but userspace should be fine?

    1. “will x86-S software run on x88-64 hardware? looks like the OS would likely need some tweaks in the booting process at the very least, but userspace should be fine?”

      It does look likely to me and it would make sense. To be confirmed of course, but probably good chances.

Leave a Reply

Your email address will not be published. Required fields are marked *