Difference between revisions of "FR:RPi Software"

From eLinux.org
Jump to: navigation, search
(traduction commencée: 22:55, 15 April 2013‎)
(Gestionnaires d'amorçage du GPU)
 
(12 intermediate revisions by the same user not shown)
Line 5: Line 5:
 
==Vue d'ensemble==
 
==Vue d'ensemble==
  
If you just want a working system, all that is required is a correctly formatted SD card. For details on how to create or get one, please see the [[RPi_Hardware_Basic_Setup#Prepared_Operating_System_SD_Card|Hardware Basic Setup]] page.
+
Si vous souhaitez juste un système qui fonctionne, tout ce dont vous avez besoin est une carte SD correctement formatée. Pour les détails sur comment la créer ou en obtenir une, veuillez lire la page [[FR:RPi_Hardware_Basic_Setup#Carte_SD_préchargée_avec_le_système_d'exploitation|Hardware Basic Setup]].
  
In order to understand the software compoonents in the RPi, you should first understand how it boots up. At power-up, the CPU is offline, and a small RISC core on the GPU is responsible for booting the SoC, therefore most of the boot components are actually run on the GPU code, not the CPU.
+
Afin de comprendre les composants logiciels du RPi, vous devez au préalable comprendre la façon dont il est amorcé. À la mise sous tension, le CPU est hors ligne, et un petit cœur RISC sur le GPU est responsable de l'amorçage du SoC, par conséquent, la plupart des éléments d'amorçage est en réalité exécutée par le code du GPU, pas par le CPU.
  
The boot order and components are as follows:
+
La séquence d'amorçage et les composants se répartissent ainsi :
* '''First stage bootloader''' - This is used to mount the FAT32 boot partition on the SD card so that the second stage bootloader can be accessed. It is programmed into the SoC itself during manufacture of the RPi and cannot be reprogrammed by a user.
+
* '''Chargeur d'amorçage de premier niveau''' - Il est utilisé pour monter la partition racine FAT32 de la carte SD afin que le chargeur de second niveau puisse être accessible. Il est programmé dans le SoC lui-même pendant la fabrication du RPi et ne peut pas être reprogrammé par l'utilisateur.
* '''Second stage bootloader''' (bootcode.bin) - This is used to retrieve the GPU firmware from the SD card, program the firmware, then start the GPU.
+
* '''Chargeur d'amorçage de second niveau''' (bootcode.bin) - Il sert à extraire le micrologiciel du GPU à partir de la carte SD, à programmer le micrologiciel, puis à démarrer le GPU.
* '''GPU firmware''' (start.elf) - Once loaded, this allows the GPU to start up the CPU. An additional file, fixup.dat, is used to configure the SDRAM partition between the GPU and the CPU. At this point, the CPU is release from reset and execution is transferred over.
+
* '''Micrologiciel du GPU''' (start.elf) - Une fois chargé, il permet au GPU de démarrer le CPU. Un autre fichier, fixup.dat, est utilisé pour configurer la répartition de la SDRAM entre le GPU et le CPU. À ce stade, le CPU sort de l'état reset et la poursuite de l'exécution lui est transférée.
* '''User code''' - This can be one of any number of binaries. By default, it is the Linux kernel (usually named kernel.img), but it can also be another bootloader (e.g. U-Boot), or a bare-bones application.
+
* '''Code utilisateur''' - Cela peut être un des binaires parmi tous ceux qu'il y a. Par défaut, il s'agit du noyau Linux (habituellement nommé kernel.img), mais ça pourrait aussi être un autre gestionnaire de démarrage (e.g. U-Boot), ou une application bare-bone.
  
Prior to 19th October 2012, there was previously also a third stage bootloader (loader.bin) but this is no longer required. <ref>https://github.com/raspberrypi/firmware/commit/c57ea9dd367f12bf4fb41b7b86806a2dc6281176</ref>
+
Avant le 19 octobre 2012, il existait aussi un troisième niveau d'amorçage (loader.bin) mais celui-ci n'est plus nécessaire. <ref>https://github.com/raspberrypi/firmware/commit/c57ea9dd367f12bf4fb41b7b86806a2dc6281176</ref>
  
Raspbian Linux image (others?) available on the foundation's website ([http://www.raspberrypi.org/downloads]) also contains cut-down versions of the above files (fixup_cd.dat, start_cd.elf). These are used when GPU memory is set to 16 MB, which in result disables some GPU features. More info [http://www.raspberrypi.org/phpBB3/viewtopic.php?p=198420#p198420 here]. In addition, there are also testing versions of the above files (fixup_x.dat, start_x.elf), which enable potentially unstable/not-fully-tested/hacky functionality - currently, using these files instead of the usual fixup.dat/start.elf will cause extra video codecs to become available.
+
L'image Raspbian Linux (autres ?) disponible sur le site web de la fondation ([http://www.raspberrypi.org/downloads]) contient également des versions tronquées des fichiers ci-dessus (fixup_cd.dat, start_cd.elf). Ils sont utilisés lorsque la mémoire GPU est définie sur 16 Mo, ce qui a pour conséquence de désactiver certaines fonctionnalités du GPU. Plus d'informations [http://www.raspberrypi.org/phpBB3/viewtopic.php?p=198420#p198420 ici]. De plus, il en existe aussi des versions de test (fixup_x.dat, start_x.elf), qui disposent de fonctionnalités pouvant être instables/pas testées entièrement/bidouillées - actuellement, l'utilisation de ces fichiers à la place des fixup.dat/start.elf classiques rend disponibles des codecs vidéo supplémentaires.
  
Because of this boot process, use of an SD card to boot the RPi is mandatory. This does however mean that you cannot 'brick' the device.
+
En raison de ce processus d'amorçage, l'utilisation d'une carte SD pour démarrer le RPi est obligatoire. Cela implique cependant que vous ne pouvez pas le 'bricker'.
  
 
==Gestionnaires d'amorçage du GPU==
 
==Gestionnaires d'amorçage du GPU==
  
Currently all of the GPU software and firmware is supplied in binary format. For Raspbian the latest stable release is included in the image and can be updated with apt-get (see the [[Add_software|adding software page]]). The latest bleeding edge version can be downloaded from the [https://github.com/raspberrypi/firmware/tree/master/boot RPI firmware section on GitHub]. At this time, the source code is not available.
+
Actuellement, l'ensemble du logiciel du GPU et le micrologiciel sont fournis sous forme binaire. Pour Raspbian, la version stable la plus récente est présente dans l'image et peut être mise à jour avec apt-get (voir la [[Add_software|page ajout de logiciel]]). La dernière version développée est téléchargeable depuis la [https://github.com/raspberrypi/firmware/tree/master/boot section RPI firmware sur GitHub]. À ce jour, le code source n'est pas disponible.
  
[https://github.com/Hexxeh/rpi-update rpi-update] is also available as an easier way of updating the firmware and kernel. Please note, as this firmware is bleeding edge, it really should only be used by advanced users and could potentially still have bugs and be incompatible with existing images.
+
[https://github.com/Hexxeh/rpi-update rpi-update] est également proposé comme un moyen plus facile de mettre à jour le noyau et le micrologiciel. Veuillez noter, comme il s'agit du tout dernier micrologiciel, qu'il ne devrait être réellement utilisé que par des utilisateurs avancés et peut encore comporter des bogues et être incompatible avec des images existantes.
  
 
==Distributions==
 
==Distributions==
''Main page: [[RPi_Distributions|Distributions]]''
+
''Page principale : [[RPi_Distributions|Distributions]]''
  
SD card images of a number of pre-built distributions including Raspbian (the RPi official distribution based on Debian),
+
Des images de cartes SD pour certaines distributions prêtes à l'emploi, dont Raspbian (la distribution officielle pour RPi, basée sur Debian),
Arch Linux ARM, and RISC OS are available from the [http://www.raspberrypi.org/downloads Raspberry Pi foundation website].
+
Arch Linux ARM, et RISC OS sont disponibles depuis le [http://www.raspberrypi.org/downloads site web de la fondation Raspberry Pi].
Pre-loaded SD cards are also available from [http://thepihut.com/collections/sd-cards The Pi Hut].
+
Des cartes SD pré-installées sont également disponibles chez [http://thepihut.com/collections/sd-cards The Pi Hut].
  
Several other Distributions  made RPI Images as well. See at http://www.raspberrypi.org/phpBB3/viewforum.php?f=18   
+
Plusieurs autres distributions proposent aussi des images pour RPI. Voir sur http://www.raspberrypi.org/phpBB3/viewforum.php?f=18   
  
Raspbian is the recommended distribution.
+
La distribution conseillée est Raspbian.
  
 
==Noyau==
 
==Noyau==
''Main page: [[RPi_Kernel_Compilation|RPi Kernel Compilation]]''
+
''Page principale : [[RPi_Kernel_Compilation|RPi Kernel Compilation]]''
  
The kernel is sources can be obtained from the [https://github.com/raspberrypi/linux RPI linux section on GitHub]
+
Les sources du noyau peuvent être obtenues depuis la [https://github.com/raspberrypi/linux section linux du RPi sur GitHub]
  
 
==Compilateur==
 
==Compilateur==
  
The Broadcom processor on Raspberry Pi contains an ARM v6 general purpose processor and a Broadcom VideoCore IV GPU. No data is currently available on other cores (if any) available in the BCM2835.
+
Le processeur Broadcom du Raspberry Pi contient un processeur ARM v6 à usage générique et un GPU Broadcom VideoCore IV. Aucune donnée n'est disponible actuellement sur la présence (éventuelle) d'autres cœurs au sein du BCM2835.
  
 
===ARM===
 
===ARM===
Line 68: Line 68:
 
===DSP===
 
===DSP===
  
There is a DSP, but there isn't currently a public API (Liz thinks the BC team are keen to make one available at some point).
+
Un DSP est présent mais il n'y a pas d'API publique pour l'instant (Liz pense que l'équipe de BC est intéressée par le fait d'en rendre une disponible un jour).
  
 
==Performances==
 
==Performances==
  
A large number of benchmark results are available on the [[RaspberryPiPerformance|performance page]].
+
Un grand nombre de résultats de tests de performances est disponible sur la [[RaspberryPiPerformance|page performances]].
  
 
==Programmation==
 
==Programmation==
A number of development environments are available depending on which language you are writing - see the [[RPi_Programming|programming]] page.
+
Des environnements de développement sont disponibles selon le langage qui vous utilisez - voir la [[FR:RPi_Programming|page programmation]].
  
 
==Émulation==
 
==Émulation==
The ARM processor on the RPi can be emulated using QEMU. See [http://cronicasredux.blogspot.co.uk/2011/09/installing-and-running-debian-armel-on.html emercer's tutorial], and also [http://www.raspberrypi.org/forum/projects-and-collaboration-general/emulating-a-raspi-on-windows this discussion].
+
Le processeur ARM du RPi peut être émulé grâce à QEMU. Voir le [http://cronicasredux.blogspot.co.uk/2011/09/installing-and-running-debian-armel-on.html tutoriel d'emercer], et également [http://www.raspberrypi.org/forum/projects-and-collaboration-general/emulating-a-raspi-on-windows cette discussion].
  
 
==Références==
 
==Références==

Latest revision as of 02:30, 16 June 2013


Retour vers le Hub.


Logiciels et Distributions :

Logiciels - une vue d'ensemble.

Distributions - systèmes d'exploitation et environnements de développement pour le Pi.

Compilation du noyau - conseils sur la compilation du noyau.

Performances - mesure des performances du Pi.

Programmation - langages de programmation utilisables sur le Pi.


Vue d'ensemble

Si vous souhaitez juste un système qui fonctionne, tout ce dont vous avez besoin est une carte SD correctement formatée. Pour les détails sur comment la créer ou en obtenir une, veuillez lire la page Hardware Basic Setup.

Afin de comprendre les composants logiciels du RPi, vous devez au préalable comprendre la façon dont il est amorcé. À la mise sous tension, le CPU est hors ligne, et un petit cœur RISC sur le GPU est responsable de l'amorçage du SoC, par conséquent, la plupart des éléments d'amorçage est en réalité exécutée par le code du GPU, pas par le CPU.

La séquence d'amorçage et les composants se répartissent ainsi :

  • Chargeur d'amorçage de premier niveau - Il est utilisé pour monter la partition racine FAT32 de la carte SD afin que le chargeur de second niveau puisse être accessible. Il est programmé dans le SoC lui-même pendant la fabrication du RPi et ne peut pas être reprogrammé par l'utilisateur.
  • Chargeur d'amorçage de second niveau (bootcode.bin) - Il sert à extraire le micrologiciel du GPU à partir de la carte SD, à programmer le micrologiciel, puis à démarrer le GPU.
  • Micrologiciel du GPU (start.elf) - Une fois chargé, il permet au GPU de démarrer le CPU. Un autre fichier, fixup.dat, est utilisé pour configurer la répartition de la SDRAM entre le GPU et le CPU. À ce stade, le CPU sort de l'état reset et la poursuite de l'exécution lui est transférée.
  • Code utilisateur - Cela peut être un des binaires parmi tous ceux qu'il y a. Par défaut, il s'agit du noyau Linux (habituellement nommé kernel.img), mais ça pourrait aussi être un autre gestionnaire de démarrage (e.g. U-Boot), ou une application bare-bone.

Avant le 19 octobre 2012, il existait aussi un troisième niveau d'amorçage (loader.bin) mais celui-ci n'est plus nécessaire. [1]

L'image Raspbian Linux (autres ?) disponible sur le site web de la fondation ([1]) contient également des versions tronquées des fichiers ci-dessus (fixup_cd.dat, start_cd.elf). Ils sont utilisés lorsque la mémoire GPU est définie sur 16 Mo, ce qui a pour conséquence de désactiver certaines fonctionnalités du GPU. Plus d'informations ici. De plus, il en existe aussi des versions de test (fixup_x.dat, start_x.elf), qui disposent de fonctionnalités pouvant être instables/pas testées entièrement/bidouillées - actuellement, l'utilisation de ces fichiers à la place des fixup.dat/start.elf classiques rend disponibles des codecs vidéo supplémentaires.

En raison de ce processus d'amorçage, l'utilisation d'une carte SD pour démarrer le RPi est obligatoire. Cela implique cependant que vous ne pouvez pas le 'bricker'.

Gestionnaires d'amorçage du GPU

Actuellement, l'ensemble du logiciel du GPU et le micrologiciel sont fournis sous forme binaire. Pour Raspbian, la version stable la plus récente est présente dans l'image et peut être mise à jour avec apt-get (voir la page ajout de logiciel). La dernière version développée est téléchargeable depuis la section RPI firmware sur GitHub. À ce jour, le code source n'est pas disponible.

rpi-update est également proposé comme un moyen plus facile de mettre à jour le noyau et le micrologiciel. Veuillez noter, comme il s'agit du tout dernier micrologiciel, qu'il ne devrait être réellement utilisé que par des utilisateurs avancés et peut encore comporter des bogues et être incompatible avec des images existantes.

Distributions

Page principale : Distributions

Des images de cartes SD pour certaines distributions prêtes à l'emploi, dont Raspbian (la distribution officielle pour RPi, basée sur Debian), Arch Linux ARM, et RISC OS sont disponibles depuis le site web de la fondation Raspberry Pi. Des cartes SD pré-installées sont également disponibles chez The Pi Hut.

Plusieurs autres distributions proposent aussi des images pour RPI. Voir sur http://www.raspberrypi.org/phpBB3/viewforum.php?f=18

La distribution conseillée est Raspbian.

Noyau

Page principale : RPi Kernel Compilation

Les sources du noyau peuvent être obtenues depuis la section linux du RPi sur GitHub

Compilateur

Le processeur Broadcom du Raspberry Pi contient un processeur ARM v6 à usage générique et un GPU Broadcom VideoCore IV. Aucune donnée n'est disponible actuellement sur la présence (éventuelle) d'autres cœurs au sein du BCM2835.

ARM

There is broad compiler support for the ARM processor including GCC - please see ARM Compilers. There are also a number of cross-compiler toolchains - please see toolchains.

The gcc compiler flags which will produce the most optimal code for the RPi are:

-Ofast -mfpu=vfp -mfloat-abi=hard -march=armv6zk -mtune=arm1176jzf-s

-Ofast may produce compile errors for some programs. In this case, -O3 or -O2 should be used instead. Note that -mcpu=arm1176jzf-s can be used in place of -march=armv6zk -mtune=arm1176jzf-s.

If you want to generate a relatively up-to-date compiler that uses the optimal flags by default, you can roll your own version of Linaro GCC - see RPi Linaro GCC Compilation.

GPU

The GPU provides APIs for Open GL ES 2.0, hardware-accelerated OpenVG, and 1080p30 H.264 high-profile decode.

The GPU is capable of 1Gpixel/s, 1.5Gtexel/s or 24 GFLOPs of general purpose compute and features a bunch of texture filtering and DMA infrastructure - the Raspberry Pi team are looking at how they can make this available to application programmers. For the documentation on some Broadcom APIs exposed to control the GPU, see RPi VideoCore APIs.

The GPU blob is an 18MB elf file, including libraries. It does an awful lot. [2]

DSP

Un DSP est présent mais il n'y a pas d'API publique pour l'instant (Liz pense que l'équipe de BC est intéressée par le fait d'en rendre une disponible un jour).

Performances

Un grand nombre de résultats de tests de performances est disponible sur la page performances.

Programmation

Des environnements de développement sont disponibles selon le langage qui vous utilisez - voir la page programmation.

Émulation

Le processeur ARM du RPi peut être émulé grâce à QEMU. Voir le tutoriel d'emercer, et également cette discussion.

Références