FX2LP est une appellation commerciale déposée par l'entreprise Cypress Semiconductor, couvrant une gamme de plusieurs microcontrôleurs conçus pour interfacer un système électronique avec un bus USB, typiquement pour rendre ce système électronique accessible depuis un ordinateur.
Il est fortement intégré et comprend :
Disponible sur le site de Cypress : CY7C68013A/14A
A l’installation de l’interface de communication CyConsole, le driver CyUSB.sys se trouve dans C:\Program Files\Cypress\USB DevStudio\Driver
Pour communiquer avec un PC, il est nécessaire d’avoir une interface de communication, pour Windows c’est la CyConsole (Cypress USB Console), disponible sur le site de Cypress à partir de SuiteUSB 1.0 - USB Development tools for Visual C++ 6.0 (2) sous le nom USBDevStudio_1703.exe : CyConsole
Une fois installé une documentation illustrée présentant l’interface (Users’Guide) CyConsole.pdf est disponible dans C:\Program Files\Cypress\USB DevStudio\CyConsole
ATTENTION : Ne pas oublier de modifier le CyUSB.inf pour que le FX2LP soit reconnu (cf : Part 3 du Users’Guide)
L’énumération est une étape qui permet d’identifier et de configurer le périphérique qui vient juste d’être branché sur le bus USB.
Pendant l’énumération le périphérique fournit à l’hôte (PC) une suite de descripteurs qui permettent son identification complète. L’hôte assigne une adresse unique au périphérique (adressage dynamique) et configure le périphérique.
Le FX2LP dispose déjà de l'énumération, aucun programme n'est nécessaire, on passe directement au transfert des données.
Plus précisément le FX2LP se compose de :
Le schéma bloc du FX2LP montre la version complète du composant (128 pins).
C'est un Intel 8051 amélioré. Il comprend :
Pour avoir plus de détails sur la configuration des registres et le fonctionnement du Microcontrôleur : EZ-USB TRM (Technical Reference Manual).
C'est un moteur d'interface intelligent (Smart Interface Engine) qui décode et encode les données sur D+/D-.
Il lit les signaux différentiels D+/D-, en extrait les données et envoie un paquet d'acquittement (ACK) pour signaler à l'hôte (PC) qu'il a bien reçu les données.
Il procède en sens inverse pour envoyer des données à l'hôte : il lit les données, les met au format USB et les envoie sur D+/D-.
C'est une interface programmable (General Programmable Interface) qui permet de générer des signaux de contrôle (CTL), des adresses (GPIFADR) et des données (FD) pour commander un périphérique externe (ASICs, DSPs...).Il peut aussi attendre un évènement externe sur les broches RDY.
Ces signaux peuvent être programmés par l'utilisateur en modifiant les registres du 8051.
Ainsi le FX2LP fonctionne en mode Maitre (Master). Le GPIF peut être synchronisé par l'horloge interne (30/48 MHz) ou par une horloge externe sur IFCLK.
Il est possible d’ajouter une EEPROM I2C. Sa fréquence de fonctionnement sera de 100 ou 400 kHz. L’EEPROM communique avec le 8051 par l’intermédiaire de 2 signaux SCL (clk) et SDA (données).
Le FX2LP gère automatiquement la mémoire I2C. Celle-ci est programmable par l'USB. Si le circuit détecte un boot loader (0xC0 ou 0xC2 sur le premier octet), alors il charge dans sa RAM, le programme contenu dans la mémoire I2C, puis l'exécute.
C’est une boucle à verrouillage de phase (Phase-Locked Loop), elle sert à multiplier ou diviser la fréquence (24 MHz) :