mercredi 19 avril 2017

Analyseur logique: installation de sigrok PulseView sous Windows

Il y a quelques semaines, je me suis procuré un analyseur logique sur eBay, un modèle ultra-économique vendu au prix de 7 euros environ.

Dans ce court article, je vous montre comment j'ai installé le logiciel sigrok Pulseview sur Windows afin d'effectuer un premier test rapide confirmant le fonctionnement correct de l'appareil.

Je tiens à préciser que je n'avais jamais eu l'occasion d'utiliser un analyseur logique auparavant.  Il serait donc illusoire d'attendre de ma part une minutieuse comparaison avec d'autres analyseurs logiques disponibles sur le marché, ou encore un cours complet sur l'art d'utiliser efficacement ce genre d'appareil.

Il s'agit donc d'un minuscule dispositif (5 cm X 2,5 cm X 1 cm) qui se branche sur le port USB d'un ordinateur.   C'est un analyseur 8 bits, ce qui signifie qu'on peut observer jusqu'à 8 signaux logiques simultanément, à une fréquence d'acquisition maximale de 24 MHz.



Mon exemplaire était accompagné d'un câble mini-USB et de 10 câbles Dupont femelles (ce qui ne constitue pas le meilleur type de connecteur, dans les circonstances).

Évidemment, à ce prix, nous ne serons pas surpris de constater que le fabricant n'a pas été spécialement pointilleux en matière de propriété intellectuelle.  Bien que ce ne soit pas indiqué sur le boîtier  (ni dans la description sur eBay), la mention "usb Saleae  V1.1"  est clairement visible sur le circuit imprimé:  il s'agit donc d'une copie d'un analyseur conçu par la compagnie américaine Saleae.



Vice de conception assez rigolo: une LED rouge s'allume pour indiquer que l'analyseur est sous tension, mais puisque cette LED est enfermée à l'intérieur d'un boîtier opaque, il est impossible de savoir si elle est allumée ou non...  On peut voir sur le circuit imprimé qu'une deuxième LED a été omise (dans le circuit d'origine, cette LED verte sert à indiquer s'il y a de l'activité sur les canaux numériques).

Côté logiciel, deux choix s'offrent à vous:
  • sigrok:  Un logiciel libre spécialement conçu pour être utilisé avec une vaste gamme d'analyseurs logiques.  C'est la voie que je vous propose ici:  ça nous permettra peut être de nous sentir un peu moins coupables d'avoir encouragé la contrefaçon...
Nous nous dirigeons donc vers la page de téléchargement de sigrok dédiée à Windows (d'autres plate-formes sont bien sûr disponibles:  Mac, Linux, Android, etc.).  Pour ma part, je l'ai installé sous Windows 7.

On nous donne le choix entre Pulseview (interface graphique) ou sigrok-cli (interface en lignes de commandes):  j'ai choisi Pulseview,


Après avoir téléchargé le programme d'installation, bien entendu, on installe le logiciel.

MAIS CE N'EST PAS TERMINÉ...

Si vous branchez l'analyseur logique dans un port USB de l'ordinateur, Windows va tenter sans succès d'installer un pilote de périphérique.  Vous devez vous-même faire l'installation de ce pilote, grâce au logiciel "Zadig", qui a été installé en même temps que Pulseview.

Dans le menu Démarrer de Windows, vous ouvrez donc Zadig, qui se trouve à l'intérieur du répertoire sigrok/PulseView.


Pendant que Zadig est ouvert, vous branchez l'analyseur logique à un port USB de l'ordinateur.  Zadig devrait le détecter ("Unknown Device #1).  Vous cliquez ensuite sur le bouton "Install Driver".


Cette fois, le pilote devrait s'installer correctement.



Nous pouvons maintenant démarrer le logiciel PulseView.  Dans un premier temps, il faut établir la connexion avec l'analyseur logique.

Vous cliquez donc sur le bouton "Connect to Device"...


...et vous choisissez le pilote "fx2lafw (generic driver for FX2 based LAs) (fx2lafw)", l'interface USB, et vous cliquez sur le bouton "Scan for devices using driver above".

La mention "Saleae Logic with 8 channels" devrait apparaître dans la case du bas.  Il ne reste plus qu'à cliquer sur le bouton "OK".


Petit test impliquant les sorties PWM d'une carte Arduino

Comme prétexte pour utiliser mon analyseur logique, j'ai activé 5 sorties PWM de l'Arduino en utilisant plusieurs rapports cycliques différents.


J'ai branché l'analyseur logique de la façon suivante:

  • Canal 0:  Pin 3
  • Canal 1:  Pin 9
  • Canal 2:  Pin 10
  • Canal 3:  Pin 11
  • Canal 4:  Pin 5
  • Canal 5:  Pin 6


Puis j'ai exécuté le sketch suivant:


Voici le résultat, dans la fenêtre principale de PulseView:



On peut remarquer le rapport cyclique de plus en plus élevé sur les canaux 0, 1, et 2.  De plus, les canaux 3 et 4 (qui correspondent aux pins 5 et 6 de l'Arduino) ont une fréquence deux fois plus élevée que les autres.

Yves Pelletier   (TwitterFacebook)

lundi 17 avril 2017

Module RFID RC522 et Raspberry Pi (Python)


Pour la quatrième fois depuis le début du mois, je vous propose de lire le numéro de série d'un tag RFID au moyen d'un module RC522.  Cette fois, c'est un Raspberry Pi qui aura l'honneur de piloter notre module RC522, grâce à un script rédigé en Python (les articles précédents mettaient plutôt en scène un Arduino, un MSP430 Launchpad et un STM32 Nucleo).

Si vous n'êtes pas déjà l'heureux propriétaire d'un module RC522, des commerçants chinois se feront un plaisir de vous en vendre un (accompagné d'un ou deux tags RFID) pour moins de 2 euros.


Activation de SPI sur le Rasbperry Pi

Le module RC522 utilise le protocole de communication SPI.  Vous devez donc vous assurer que le SPI est activé sur votre Raspberry Pi.  Pour ce faire, vous choisissez "Configuration du Raspberry Pi" dans le menu "Préférences"...


...et vous vous assurez que SPI est activé.


(C'est fou comme les choses évoluent rapidement dans le monde du Raspberry Pi:  y a-t-il quelqu'un quelque part qui s'ennuie de raspi-config?)

Installation de la bibliothèque pi-rc522

Nous utiliserons la bibliothèque pi-rc522 par ondryaso.  Pour ce faire, la façon la plus simple (à mon avis), est d'utiliser pip:

sudo pip install pi-rc522

La bibliothèque est alors installée dans le répertoire /usr/local/python2.7/dist-packages.

Circuit (connexions)

Les connexions à effectuer sont:
  • Pin SDA du RC522 --- Pin #24 (GPIO 8) du Raspberry Pi
  • Pin SCK du RC522 --- Pin#23 (GPIO 11) du Raspberry Pi
  • Pin MOSI du RC522 --- Pin #19 (GPIO 10) du Raspberry Pi
  • Pin MISO du RC522 --- Pin #21 (GPIO 9) du Rasbperry Pi
  • Pin IRQ du RC522 --- Pin #18 (GPIO 24) du Raspberry Pi
  • Pin GND du RC522 --- Une des pins GND du Raspberry Pi
  • Pin RST du RC522 --- Pin #22 (GPIO 25) du Raspberry Pi
  • Pin 3V3 du RC522 --- Pin 3V3 du Raspberry Pi
  • LED verte (et résistance) --- Pin #15 (GPIO 22) du Raspberry Pi
  • LED rouge (et résistance) --- Pin #16 (GPIO 23) du Rasbperry Pi



Script pour récupérer l'UID

Voici un premier script en Python qui affiche  dans le terminal l'UID (numéro de série) d'un tag RFID qu'on approche du module RC522.




Sur la capture d'écran ci-dessus, vous pouvez constater que l'UID de la carte que j'ai utilisée est constituée des valeurs 144, 207, 148, 117 et 190.  Ces nombres seront utilisés dans le prochain script.


Script qui accepte ou rejette l'UID

L'idée est d'accomplir une action seulement si l'utilisateur présente un tag RFID dont l'UID est approuvé.  Avec ce script en Python, la LED verte s'allume uniquement lorsqu'on approche un tag RFID portant le bon UID.  Si on approche un tag RFID portant un autre UID, c'est la LED rouge qui s'allume.

Avant d'utiliser le script, n'oubliez pas de remplacer le contenu de la variable "bonUID" par l'UID de votre carte.

Vous pourrez ensuite modifier ce script de base pour en faire quelque chose de plus utile ou plus spectaculaire (actionner une serrure, mettre à jour une base de donnée consignant l'heure d'entrée et sortie des employés, etc.).



Yves Pelletier   (TwitterFacebook)

samedi 15 avril 2017

Module RFID RC522 et STM32 Nucleo (mbed)


Après avoir expérimenté mon module RFID RC522 avec une carte Arduino et avec une carte MSP430 Launchpad, c'est maintenant au tour de ma carte STM32 Nucleo...

Tout comme ce fut le cas avec les deux autre microcontrôleurs, nous verrons comment récupérer l'UID (numéro de série) d'un tag RFID, puis nous élaborerons un dispositif qui allume une LED verte lorsque l'UID est accepté, et une LED rouge lorsque l'UID n'est pas accepté.

Le circuit

Le module RC522 utilise le protocole SPI pour communiquer avec le  microcontrôleur.  Son niveau logique de 3,3 V correspond parfaitement à celui du SMT32 Nucleo.

Les branchements appropriés sont:
  • Pin SDA du RC522 --- Pin PWM/CS/D10 du Nucleo
  • Pin SCK du RC522 --- Pin SCK/D13 du Nucleo
  • Pin MOSI du RC522 --- Pin PWM/MOSI/D11 du Nucleo
  • Pin MISO du RC522 --- Pin MISO/D12 du Nucleo
  • Pin IRQ du RC522 --- Pas branchée
  • Pin GND du RC522 --- Pin GND du Nucleo
  • Pin RST du RC522 --- Pin D8 du Nucleo
  • Pin 3V3 du RC522 --- Pin 3V3 du Nucleo
  • LED verte (et résistance) --- Pin D2 du Nucleo
  • LED rouge (et résistance) --- Pin D3 du Nucleo
Remarquez que, du côté Nucleo, nous utilisons les connecteurs femelles compatibles Arduino.

Importation du programme RC522_LF dans embed

Dans mbed, j'ai importé un programme intitulé "RC522_LF", dont l'auteur est "Team FRA221:A" (bouton "Import").


Ce programme permet de récupérer l'UID d'un tag RFID amené à proximité du module RC522.  De plus, il contient la bibliothèque MFRC522 qui nous sera bien utile pour la réalisation de nos propres programmes.

Récupération de l'UID

Pour connaître l'UID de vos tags RFID, il s'agit de compiler sans modification le programme "RC522_LF", et de le téléverser dans la carte Nucleo.  Vous ouvrez ensuite sur l'ordinateur un terminal permettant la communication série (j'ai utilisé le moniteur série de l'IDE Arduino), réglé à 57600 bauds.  L'UID et le type de cartes s'affichent chaque fois que vous approchez un tag RFID.


Petit inconvénient:  le programme insère inutilement le nombre "02" à la fin de chaque octet constituant l'UID.  Ainsi, pour le premier tag que j'ai approché du module, il m'affiche comme UID "9002 CF02 9402 7502", ce qui signifie que l'UID est, en fait "90 CF 94 75" (en hexadécimal).  Vous pouvez facilement modifier le programme pour corriger le problème, ou simplement ne pas tenir compte des "02" superflus.

Un script qui approuve ou rejette un UID

Pour faire nos propres programmes, il s'agit de faire une copie du projet "RC522_LF" (incluant sa bibliothèque) et de modifier le fichier "main.cpp".  Le script ci-dessous allume la LED verte lorsque l'UID est approuvé, et allume la LED rouge quand il s'agit d'un autre UID.

Évidemment, vous devez d'abord remplacer le contenu de la constante "bonUID" par la valeur récupérée à l'étape précédente.  Remarquez que, puisque les octets sont en hexadécimal, chaque valeur est précédée du symbole "0x".



N.B.: Ce projet a également été réalisé avec Arduino, Raspberry Pi et MSP430 Launchpad.

Yves Pelletier   (TwitterFacebook)

Related Posts Plugin for WordPress, Blogger...