Projet

Général

Profil

Programmation sous Linux » Historique » Version 31

Patrice Nadeau, 2014-08-17 11:13

1 4 Patrice Nadeau
%{font-size:18pt}Programmation sous Linux%
2 1 Patrice Nadeau
3 26 Patrice Nadeau
> Mon BBB (révision C) roule sous Debian 7 (wheezy)
4 25 Patrice Nadeau
5 24 Patrice Nadeau
----
6
7
{{TOC}}
8
9 3 Patrice Nadeau
h1. GPIO(General Purpose Input/Output)
10 5 Patrice Nadeau
11
Un petit calcul doit-être fait pour déterminer la correspondance entre le nom BBB et celui sous Linux.
12
13
14
Télécharger le "System Reference Manual":http://elinux.org/Beagleboard:BeagleBoneBlack#Hardware_Files
15
16
La section *PRU-ICSS Pin Access* est celle qui nous intéresse.
17
18 20 Patrice Nadeau
Le calcul est le suivant :
19 5 Patrice Nadeau
Multiplier le numéro du chip par 32 et ajouter le numéro de la pin.
20 6 Patrice Nadeau
>Exemple : Pour utiliser la pin 12 du connecteur P8 (GPIO1_12), le signal correspondant sous Linux est le *44* (1 x 32 + 12 = 44).
21 7 Patrice Nadeau
22 12 Patrice Nadeau
L'utilisation d'une pin se fait en 4 étapes
23 11 Patrice Nadeau
# Exporter la pin
24
# Choisir la direction
25
# Choisir la valeur
26
# Enlever l'export de la pin
27
28 7 Patrice Nadeau
h2. Ligne de commande
29
30 12 Patrice Nadeau
Exporter la pin 
31 7 Patrice Nadeau
<pre><code class="bash">
32 9 Patrice Nadeau
echo 44 > /sys/class/gpio/export
33 7 Patrice Nadeau
</code></pre>
34
35
Un dossier _gpio44_ existe maintenant.
36
37
Le fichier *direction* sélectionne le mode d'utilisation de la pin :
38
* *in* : Entré
39
* *out* : Sortie
40 1 Patrice Nadeau
41 8 Patrice Nadeau
<pre><code class="bash">
42 17 Patrice Nadeau
echo out > /sys/class/gpio/gpio44/direction
43 8 Patrice Nadeau
</code></pre>
44
45
46
Le fichier *value* sélectionne la valeur de la pin :
47
* *0* : Low
48 1 Patrice Nadeau
* *1* : High
49
50
<pre><code class="bash">
51 9 Patrice Nadeau
echo 1 > /sys/class/gpio/gpio44/value
52
</code></pre>
53
54 13 Patrice Nadeau
Une fois terminé, on doit enlever le « export » de la pin
55 9 Patrice Nadeau
<pre><code class="bash">
56 21 Patrice Nadeau
echo 44 > /sys/class/gpio/unexport
57 8 Patrice Nadeau
</code></pre>
58 10 Patrice Nadeau
59
h2. C
60 14 Patrice Nadeau
61 15 Patrice Nadeau
La librairie _stdio.h_ seras utilisée avec les fonctions :
62
* fopen()
63
* fwrite()
64
* fclose()
65 16 Patrice Nadeau
66 18 Patrice Nadeau
Code
67
> Aucune vérification d'erreur I/O n'est faite dans cette exemple !
68 16 Patrice Nadeau
<pre><code class="c">
69
#include <stdio.h>
70
71 1 Patrice Nadeau
int main(void)
72 18 Patrice Nadeau
{
73 19 Patrice Nadeau
    FILE *fp;
74 1 Patrice Nadeau
75 19 Patrice Nadeau
    /* Export */
76
    fp = fopen("/sys/class/gpio/export","w");
77
    fwrite("44", sizeof(char), 2, fp);
78
    fclose(fp);
79 18 Patrice Nadeau
80 19 Patrice Nadeau
    /* Direction */
81
    fp = fopen("/sys/class/gpio/gpio44/direction","w");
82
    fwrite("out", sizeof(char), 3, fp);
83
    fclose(fp);
84 18 Patrice Nadeau
85 19 Patrice Nadeau
    /* Value */
86
    fp = fopen("/sys/class/gpio/gpio44/value","w");
87
    fwrite("1", sizeof(char), 1, fp);
88
    fclose(fp);
89 18 Patrice Nadeau
}
90 16 Patrice Nadeau
</code></pre>
91 23 Patrice Nadeau
92
h1. Entré analogique
93 1 Patrice Nadeau
94 26 Patrice Nadeau
> Voir issue #11
95
96 30 Patrice Nadeau
La lecture est faite à partir de 1.8 Volts en incréments de &#8776; 1 mV (de 0 @ 1798).
97 29 Patrice Nadeau
98 27 Patrice Nadeau
Activer les ports ADC
99
100
<pre><code class="bash">
101 28 Patrice Nadeau
echo cape-bone-iio > /sys/devices/bone_capemgr.9/slots
102 27 Patrice Nadeau
</code></pre>
103
104
Les différents ports (8) sont maintenant disponibles à _/sys/devices/ocp.2/helper.15_
105 31 Patrice Nadeau
> AIN7 n'est pas disponible sur les connecteurs.
106 27 Patrice Nadeau
107
La lecture peut être faite directement avec la commande _cat_
108
109 1 Patrice Nadeau
h1. Sortie analogique (PWM(Pulse Width Modulation))
110 26 Patrice Nadeau
111
> Voir issue #12