123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238 |
- #include <wiringPi.h>
- #include <iostream>
- #include <stdio.h>
- #include <sys/time.h>
- #include <time.h>
- #include <stdlib.h>
- #include <sched.h>
- #include <sstream>
- /*
- 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
- */
- //g++ radioEmission.cpp -o radioEmission -lwiringPi pour recompiler
- using namespace std;
- int pin;
- bool bit2[26]={}; // 26 bit Identifiant emetteur
- bool bit2Interruptor[4]={};
- int interruptor;
- int sender;
- string onoff;
- int pulse=0;
- void log(string a){
- //Décommenter pour avoir les logs
- //cout << a << endl;
- }
- 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
- }
- void action (bool b) {
- if (b) {
- log("envois du signal ON");
- } else {
- log("envois du signal OFF");
- }
- for(int i=0;i<5;i++){
- transmit(b); // envoyer
- delay(10); // attendre 10 ms (sinon le socket nous ignore)
- }
- }
- int main (int argc, char** argv)
- {
- if (setuid(0))
- {
- perror("setuid");
- return 1;
- }
- scheduler_realtime();
- log("Demarrage du programme");
- pin = atoi(argv[1]);
- sender = atoi(argv[2]);
- interruptor = atoi(argv[3]);
- onoff = argv[4];
- if (argc==6) {
- pulse = atoi(argv[5]);
- }
- //Si on ne trouve pas la librairie wiringPI, on arrête l'execution
- if(wiringPiSetup() == -1)
- {
- log("Librairie Wiring PI introuvable, veuillez lier cette librairie...");
- return -1;
- }
- pinMode(pin, OUTPUT);
- log("Pin GPIO configure en sortie");
- itob(sender,26); // convertion du code de l'emetteur (ici 8217034) en code binaire
- itobInterruptor(interruptor,4);
-
-
- if(onoff=="on"){
- action(true);
- }else if (onoff=="off"){
- action(false);
-
- }else{
- action(true);
- delay(pulse);
- action(false);
-
- }
- log("fin du programme"); // execution terminée.
- scheduler_standard();
- }
|