123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- #include <wiringPi.h>
- #include <stdio.h>
- #include <sys/time.h>
- #include <time.h>
- #include <stdlib.h>
- #include <sched.h>
- #include <string.h>
- /*
- Par Idleman (idleman@idleman.fr - http://blog.idleman.fr)
- Licence : CC by sa
- Toutes question sur le blog ou par mail, possibilité de m'envoyer des bières via le blog
- */
- int pin;
- bool bit2[26]={}; // 26 bit Identifiant emetteur
- bool bit2Interruptor[4]={};
- int interruptor;
- int sender;
- char onoff;
- void scheduler_realtime()
- {
- struct sched_param p;
- p.__sched_priority = sched_get_priority_max(SCHED_RR);
- if (sched_setscheduler( 0, SCHED_RR, &p ) == -1 ) {
- perror("Failed to switch to realtime scheduler.");
- }
- }
- void scheduler_standard()
- {
- struct sched_param p;
- p.__sched_priority = 0;
- if( sched_setscheduler( 0, SCHED_OTHER, &p ) == -1 ) {
- perror("Failed to switch to normal scheduler.");
- }
- }
- //Envois d'une pulsation (passage de l'etat haut a l'etat bas)
- //1 = 310µs haut puis 1340µs bas
- //0 = 310µs haut puis 310µs bas
- void sendBit(bool b) {
- if (b) {
- digitalWrite(pin, HIGH);
- delayMicroseconds(310); //275 orinally, but tweaked.
- digitalWrite(pin, LOW);
- delayMicroseconds(1340); //1225 orinally, but tweaked.
- } else {
- digitalWrite(pin, HIGH);
- delayMicroseconds(310); //275 orinally, but tweaked.
- digitalWrite(pin, LOW);
- delayMicroseconds(310); //275 orinally, but tweaked.
- }
- }
- //Calcul le nombre 2^chiffre indiqué, fonction utilisé par itob pour la conversion decimal/binaire
- unsigned long power2(int power)
- {
- unsigned long integer=1;
- for (int i=0; i<power; i++){
- integer*=2;
- }
- return integer;
- }
- //Convertis un nombre en binaire, nécessite le nombre, et le nombre de bits souhaité en sortie (ici 26)
- // Stocke le résultat dans le tableau global "bit2"
- void itob(unsigned long integer, int length)
- {
- for (int i=0; i<length; i++){
- if ((integer / power2(length-1-i))==1) {
- integer-=power2(length-1-i);
- bit2[i]=1;
- } else {
- bit2[i]=0;
- }
- }
- }
- void itobInterruptor(unsigned long integer, int length)
- {
- for (int i=0; i<length; i++) {
- if ((integer / power2(length-1-i))==1) {
- integer-=power2(length-1-i);
- bit2Interruptor[i]=1;
- } else {
- bit2Interruptor[i]=0;
- }
- }
- }
- //Envoie d'une paire de pulsation radio qui definissent 1 bit réel : 0 =01 et 1 =10
- //c'est le codage de manchester qui necessite ce petit bouzin, ceci permet entre autres de dissocier les données des parasites
- void sendPair(bool b) {
- if(b) {
- sendBit(true);
- sendBit(false);
- } else {
- sendBit(false);
- sendBit(true);
- }
- }
- //Fonction d'envois du signal
- //recoit en parametre un booleen définissant l'arret ou la marche du matos (true = on, false = off)
- void transmit(int blnOn)
- {
- int i;
- // Sequence de verrou anoncant le départ du signal au recepeteur
- digitalWrite(pin, HIGH);
- delayMicroseconds(275); // un bit de bruit avant de commencer pour remettre les delais du recepteur a 0
- digitalWrite(pin, LOW);
- delayMicroseconds(9900); // premier verrou de 9900µs
- digitalWrite(pin, HIGH); // high again
- delayMicroseconds(275); // attente de 275µs entre les deux verrous
- digitalWrite(pin, LOW); // second verrou de 2675µs
- delayMicroseconds(2675);
- digitalWrite(pin, HIGH); // On reviens en état haut pour bien couper les verrous des données
- // Envoie du code emetteur (272946 = 1000010101000110010 en binaire)
- for(i=0; i<26;i++) {
- sendPair(bit2[i]);
- }
- // Envoie du bit définissant si c'est une commande de groupe ou non (26em bit)
- sendPair(false);
- // Envoie du bit définissant si c'est allumé ou eteint 27em bit)
- sendPair(blnOn);
- // Envoie des 4 derniers bits, qui représentent le code interrupteur, ici 0 (encode sur 4 bit donc 0000)
- // nb: sur les télécommandes officielle chacon, les interrupteurs sont logiquement nommés de 0 à x
- // interrupteur 1 = 0 (donc 0000) , interrupteur 2 = 1 (1000) , interrupteur 3 = 2 (0100) etc...
- for(i=0; i<4;i++) {
- if(bit2Interruptor[i]==0){
- sendPair(false);
- } else {
- sendPair(true);
- }
- }
- digitalWrite(pin, HIGH); // coupure données, verrou
- delayMicroseconds(275); // attendre 275µs
- digitalWrite(pin, LOW); // verrou 2 de 2675µs pour signaler la fermeture du signal
- delayMicroseconds(2675);
- }
- int main (int argc, char** argv)
- {
- pin = atoi(argv[1]);
- sender = atoi(argv[2]);
- interruptor = atoi(argv[3]);
- onoff = (strcmp(argv[4], "on")==0);
- //Si on ne trouve pas la librairie wiringPI, on arrête l'execution
- if (wiringPiSetup() == -1) {
- printf("Librairie Wiring PI introuvable, veuillez lier cette librairie...\n");
- return -1;
- }
- pinMode(pin, OUTPUT);
- printf("Pin GPIO configure en sortie\n");
- itob(sender,26); // convertion du code de l'emetteur (ici 8217034) en code binaire
- itobInterruptor(interruptor,4);
- scheduler_realtime();
- if(onoff){
- printf("envoi du signal ON\n");
- for(int i=0;i<5;i++){
- transmit(true); // envoyer ON
- }
- } else {
- printf("envoi du signal OFF\n");
- for(int i=0;i<5;i++){
- transmit(false); // envoyer OFF
- }
- }
- scheduler_standard();
- }
|