Vous êtes nouveau sur Developpez.com ? Créez votre compte ou connectez-vous afin de pouvoir participer !

Vous devez avoir un compte Developpez.com et être connecté pour pouvoir participer aux discussions.

Vous n'avez pas encore de compte Developpez.com ? Créez-en un en quelques instants, c'est entièrement gratuit !

Si vous disposez déjà d'un compte et qu'il est bien activé, connectez-vous à l'aide du formulaire ci-dessous.

Identifiez-vous
Identifiant
Mot de passe
Mot de passe oublié ?
Créer un compte

L'inscription est gratuite et ne vous prendra que quelques instants !

Je m'inscris !

SiFive annonce le premier processeur RISC-V à exécution dans le désordre
La gamme U8 devrait entrer en concurrence avec les ARM de milieu de gamme

Le , par dourouc05

31PARTAGES

16  0 
RISC-V est une architecture qui fait de plus en plus parler d'elle. Elle a commencé comme un projet de recherche académique, mais orienté vers le déploiement : bon nombre de projets de recherche au niveau de l'architecture des processeurs sont volontairement simplistes, mais pas RISC-V. L'université de Berkeley a alors accepté de mettre tous les documents de conception sous licence BSD, c'est-à-dire que cette architecture est entièrement libre : aucune licence à payer à qui que ce soit pour l'utiliser, contrairement à ARM. Depuis lors, le succès de RISC-V est tel que même des sociétés comme Western Digital remplacent toutes leurs puces, notamment ARM, par du RISC-V (même la conception physique de ces puces est libérée). Pour beaucoup, cependant, le risque de changer complètement d'architecture dépasse fortement les économies qu'ils pourraient réaliser…

SiFive est une société qui gravite autour de RISC-V et conçoit des cœurs de calcul avec cette architecture ; elle a été fondée par une série de chercheurs derrière l'architecture RISC-V. De fait, les documents initiaux ne permettent pas la réalisation d'un processeur, ils spécifient "juste" l'architecture. À part Western Digital, il n'existe pas vraiment de cœur de calcul de relativement haute performance sous licence libre : c'est dans ce marché que SiFive opère, de manière similaire à ARM.


La dernière annonce de SiFive concerne justement un processeur à plus haute performance que les actuels : il est bien plus complexe et peut réordonner les instructions avant de les exécuter. Cela nécessite une grande quantité de transistors pour l'implémentation, mais aussi une analyse fine du comportement du reste du processeur pour savoir quel réordonnancement des instructions permettra d'augmenter l'utilisation du processeur. En effet, quand le processeur récupère une information dans un cache lointain, il peut utiliser ses composants pour effectuer une addition sur deux nombres disponibles dans ses registres, par exemple. Tous les processeurs modernes utilisent des principes de ce genre.

Jusqu'à présent, SiFive proposait deux séries de microarchitectures pour des charges de travail lourdes en 64 bits (contrôleurs pour voitures ou drones, points d'accès WiFi ou 5G, télévisions, etc.) : les U5 et U7, avec une exécution dans l'ordre et un pipeline de longueur variable (à 5 étages pour les U5 et 8 pour les U7, ces derniers étant superscalaires). Les U8 apportent une exécution dans le désordre et un pipeline bien plus profond : 12 étages (par rapport à une quinzaine chez Intel depuis le lancement des Core, par exemple). De fait, en performance, ils peuvent monter bien plus haut : ils peuvent traiter certaines tâches quatre à cinq fois plus rapidement que les U5 et U7.


La série des U8 se compare directement aux ARM Cortex A72 : officiellement, elle offre une performance par watt multipliée par 1,5 et utilise moitié moins de surface de silicium. Certes, le A72 n'est pas tout récent, mais les U8 devraient pouvoir entrer en compétition avec les processeurs ARM actuels de milieu de gamme (mais pas avec pareils chiffres). Il semblerait que le haut de gamme ARM ne soit pas encore atteignable, mais cela ne saurait tarder.


SiFive ne révèle pas tous les paramètres de son architecture (comme les caches), notamment parce qu'elle peut être mise à l'échelle : les différents modèles de la série pourront adopter plusieurs valeurs. Le pipeline général peut gérer trois unités d'exécution simultanément (par rapport à une pour la série U5 et deux pour la U7). À chaque cycle, le cœur peut récupérer seize octets d'instructions du cache L1I (les instructions n'ont pas de longueur fixe…) : le décodeur peut gérer quatre instructions simultanément, ce qui correspond à une longueur moyenne d'instruction de quatre octets. Après coup, la file d'attente des instructions ne peut traiter que trois instructions à la fois, une différence rarement vue en pratique (sauf pour la microarchitecture Intel Tremont), qui finiront dans des files d'attente pour chaque partie du cœur de calcul (opérations en virgule flottante, sur des nombres entiers ou en mémoire).


Avec le cœur U84, SiFive vise une fréquence de 2,6 GHz avec une lithographie en 7 nm. En omettant les caches de niveau 2, un seul cœur devrait occuper une surface de 0,28 mm² ; un processeur de quatre cœurs et un cache partagé de deux mégaoctets devraient occuper 2,63 mm². En comparaison, un ARM Cortex A55 (dont la performance est approximativement la moitié de celle d'un A72), un cœur avec son cache (128 ko) utilise 0,36 mm².


SiFive peut aussi créer des processeurs avec des cœurs très différents, partageant tous un même cache de niveau 2, pour s'adapter à toutes les situations.


Source : AnandTech.

Une erreur dans cette actualité ? Signalez-le nous !

Avatar de melka one
Membre éprouvé https://www.developpez.com
Le 16/11/2019 à 9:56
SiFive ne révèle pas tous les paramètres de son architecture (comme les caches)
c'est open source ou pas ?
1  0 
Avatar de chrtophe
Responsable Systèmes https://www.developpez.com
Le 17/11/2019 à 9:47
Il s'agit ici que d'une architecture normalisée de CPU. Un peu comme la norme x86 qui est utilisée par des fabricants différents comme Intel ou AMD. Bien que compatibles au niveau du jeu d'instruction, leur fonctionnement interne diffère (pour un résultat identique).

Bien qu'il reste possible que fabriquer un CPU pour un micro-ordinateur, l'usage pour les industriels sera plutôt pour des CPU dédiés à des usages précis.

La norme RSIC-V permet l'implementation ou non de fonctionnalités selon ses besoins.
https://fr.wikipedia.org/wiki/RISC-V...%A9cifications

https://www.developpez.com/actu/2359...s-open-source/
1  0 
Avatar de Uther
Expert éminent sénior https://www.developpez.com
Le 16/11/2019 à 10:10
L’architecture de base de RISC-V, oui.
L'implémentation particulière qu'en a fait SiFive, visiblement non.
0  0 
Avatar de melka one
Membre éprouvé https://www.developpez.com
Le 16/11/2019 à 10:34
On vas de ce retrouver une multitude de processeur basé sur la même architecture mais incompatibles entre eux .
0  2 
Avatar de redcurve
Membre confirmé https://www.developpez.com
Le 16/11/2019 à 11:43
Citation Envoyé par melka one Voir le message
On vas de ce retrouver une multitude de processeur basé sur la même architecture mais incompatibles entre eux .
Ouais je trouve ça géniale imagine ce futur complètement open source ou chaque application ne peut fonctionnement que sur la machine ou elle a été compilé ^^ Ah cette gestion du chaos encore plus grande que celle des paquets Linux
0  2