La course à la puissance CPU (1/3) : une histoire d’architectures

Pierre Dandumont |

Un gain de vitesse, c'est ce qui est attendu par tous lors de l'achat d'un nouvel ordinateur ou d'un nouveau téléphone. Mais comment Apple et les autres fabricants accélèrent-ils leurs processeurs année après année, ou du moins tentent-ils de le faire ? Premiers éléments de réponse dans notre série « La course à la puissance CPU » avec l'enjeu des architectures.

La course à la puissance CPU 🏎️
  1. Une histoire d'architectures
  2. Des évolutions gravées dans le silicium
  3. La réussite éclatante d'Apple

D'abord, commençons par définir ce que nous appellerons une « architecture » dans la suite : il s'agit de la structure interne du processeur. Elle comprend, au sens large, les différentes unités, les choix effectués par les concepteurs, les fonctions du CPU, etc. Le mot peut avoir une définition assez étendue, et nous allons prendre l'exemple d'AMD, parce que la société numérote ses architectures, ce qui simplifie l'explication. Dans la suite, nous mettrons les noms des architectures en italique, pour les démarquer des noms de code qui coïncident parfois.

Schéma d'une architecture AMD (Zen 4).

L'architecture de base s'appelle Zen, et elle date de 2017 avec les premiers Ryzen. Zen est d'une conception moderne et AMD est parti de zéro1 pour succéder à Bulldozer, qui avait été décliné dans quatre versions. AMD a ensuite modifié Zen en Zen+ (qui n'est pas considéré comme une architecture à part entière), Zen 2, Zen 3 et Zen 4, celle vue actuellement dans les Ryzen 7000. Selon le point de vue, vous pouvez estimer que toutes les puces emploient l'architecture Zen, ou, et c'est une vision plus courante, penser que Zen, Zen 2, Zen 3 et Zen 4 sont des architectures différentes, les trois dernières étant dérivées de Zen.

Pourquoi ne pas voir Zen+ comme une architecture à part entière ? Parce qu'il n'y a pas de divergences fondamentales entre Zen et Zen+. Le nombre d'unités est identique, tout comme la structure interne et les performances. AMD a bien optimisé certains points, gravé les puces plus finement (du 14 au 12 nm) et augmenté un peu la fréquence, mais les modifications sont trop faibles pour que Zen+ soit considéré comme une architecture séparée.

A contrario, Zen 2, Zen 3 et Zen 4 amènent de gros changements internes, parfois très conséquents. Pour schématiser, si les unités sont repensées de façon substantielle, nous sommes face à une nouvelle architecture. Si les révisions se résument à des optimisations pour monter en fréquence, ce n'est pas le cas.

Ce Ryzen 5 2600 est en pratique identique à un Ryzen 5 1600, en dehors d'une fréquence un peu plus élevée.

Pour bien relier tout ceci à Apple, les différentes analyses disponibles sur les puces A et M montrent que pour le moment Apple a régulièrement choisi de modifier l'architecture lors d'un changement de nom, à l'exception probablement des passages de l'A9 à l'A10 et de l'A14 à l'A15.

Comment améliorer un processeur ?

La première méthode qui permet d'améliorer un CPU, vous vous en doutez au vu des explications, consiste à changer d'architecture. Il peut y avoir d'autres leviers, mais nous allons considérer que c'est le seul bouleversement pour la démonstration. Une nouvelle architecture peut être de deux types : les concepteurs peuvent soit partir d'une page blanche, soit modifier une puce précédente. Cette seconde voie est logiquement la plus courante : il est plus simple de démarrer à partir de quelque chose qui fonctionne et de tenter de l'améliorer que de recommencer de zéro.

avatar PixelCat | 

C’est pour ce genre d’article que l’on paye son abonnement ; merci mille fois et j’ai hâte de lire la suite !!!

avatar serenity | 

@PixelCat

Bof je trouve que cet article n’apporte pas grand chose. Tout au plus une vision très sommaire et commerciale des processeurs sans en détailler les fonctionnements de base et les vrais enjeux.

avatar vicento | 

@serenity

Peut-être en connais tu déjà trop avant de lire l’article

Pour ma part je vais lire la suite

avatar House M.D. | 

Excellent article, comme d’habitude Pierre 😉

avatar urza25000 | 

Super article, comme toujours! Merci Pierre !

avatar Simbapple | 

Super intéressant bravo à l’auteur ! Hâte de lire la suite !

avatar Rom 1 | 

Série intéressante qui permet de rappeler les bases mais surtout revient sur l’historique de chaque constructeur ou plutôt d’architecte.

avatar stefhan | 

Qu'est-ce que j'aime ce genre d'article hyper instructifs, merci Pierre !

avatar Kuro | 

Merci pour l’article, hâte de lire la suite!

avatar dorninem | 

Super article, je vois que Amd ne fait pas mieux qu’intel concernant le nommage incompréhensible de ses processeurs : un chiffre plus élevé, un numéro de génération supérieur ne donne en fait pas forcément une puissance réelle supérieure.

Apple avec ses SOC pour l’Apple Watch a aussi fait de même ou pire en changeant le numéro juste pour faire croire à une évolution 😁

avatar pocketalex | 

J’ai appris tellement de choses ! Bravo

avatar iftwst | 

vivement la suite, merci Pierre !

avatar ERSoftware | 

Il y a encore d'autres astuces pour augmenter les performances d'un processeur: mémoire cache, unités spécialisées pour certains calculs, …
Mais l'article comme ça est déjà très bien ! 😅

avatar cecile_aelita | 

Très intéressant

avatar Ariéhm | 

Bonjour,
Oui c'est ce genre d'article qui rend se site incontournable !
très intéressant et complet!
Merci

avatar Kaserskin | 

Je m’attendais à un peu plus de détails dans la veine des articles CPC Hardware (c’est un article sur les architectures mais on ne parle pas du detail de ces dernières, comment elles sont construites concrètement (cf l’image d’illustration amd au debut)) mais c’est deja super de retrouver des articles pédagogique ici desormais !

avatar raoolito | 

excellent article et debut de série !! bravo

avatar BingoBob | 

J’aime beaucoup ces séries d’articles sur les processeurs.
J’aimerai d’ailleurs en apprendre plus sur les cœurs. Comment ils se différencient des processeurs, etc.

avatar TheRV | 

Merci !

CONNEXION UTILISATEUR