app4

Dependencies:   mbed-rtos mbed CRC16

Fork of S5info_APP2 by Éric Bisson

main.cpp

Committer:
JoeyDionne
Date:
2017-03-07
Revision:
12:a55f77a0e188
Parent:
11:b27d1a83f688
Child:
13:a436ba0b78e8

File content as of revision 12:a55f77a0e188:

#include "mbed.h"
#include "rtos.h"
#include "bit.h"
#include "uart.h"

const float HALF_PERIOD = 0.05; // secondes

Serial pc(USBTX, USBRX, 9600);
Serial uart(p13, p14, 9600);
Thread ThreadLecture;

bool transmit = false;      //faux pour le debut de demi-periode d'envoie d'un bit, vrai pour la 2ème demi-periode
char trame_sent[80];        //tableau de la trame à envoyer
uint8_t byte_sent_pos,      //position de l'octet dans le tableau d'envoi
        bit_sent,           //position du bit de l'octet en cours d'envoi (du MSB au LSB) 7..0
        trame_length;       //longueur de la trame complete
//test

bool bIsHalfPeriod = false;
  
extern "C" void RIT_IRQHandler(void) {
    //clear flag
    LPC_RIT->RICTRL |= bit0; //write 1 to clear bit
    
    bIsHalfPeriod = !bIsHalfPeriod;
}

void p14_interrupt()
{    
    // On turn off les interrupts de lecture une fois qu'on a détecter un message
    uart.attach(NULL, uart.RxIrq);

    // On envoie le signal au thread de lecture
    ThreadLecture.signal_set(1);
};

void read()
{
    while(true) 
    {
        // Attente passive d'un message entrant
        uart.attach(&p14_interrupt, uart.RxIrq);
        ThreadLecture.signal_wait(1);
        
        // Lis le message. Retourne une exception si il y a une erreur
        vector<char> message = uart_read(uart);
        
        if (!message.empty())
        {
            // Affiche le message à l'écran
            pc.printf(&message[0], message.size());
        }
    }
};

void rit_init()
{
    LPC_SC->PCONP |= bit16;                             //Power Control for Peripherals register: power up RIT clock
    LPC_SC->PCLKSEL1 |= (bit26 && bit27);               //Peripheral clock selection: divide clock by 8 (run RIT clock by 12.5MHz)
    LPC_RIT->RICOUNTER = 0;                             //set counter to zero
    LPC_RIT->RICOMPVAL = 250000000 * HALF_PERIOD;       //interrupt tick every HALF_PERIOD
    LPC_RIT->RICTRL |= bit1;                            // clear timer when counter reaches value
    LPC_RIT->RICTRL |= bit3;                            // enable timer
     
    //enable interrupt
    NVIC_SetPriority(RIT_IRQn, 31);
    NVIC_EnableIRQ(RIT_IRQn);
};

void send_data()
{
    if (!transmit) { //Si on est dans la premiere demi-periode d'envoie
        if (((trame_sent[byte_sent_pos] >> bit_sent) & 0x01) == 1) { //Verifier le bit à envoyer et preparer la prochaine interruption pour prendre sa valeur
            LPC_RIT->EMR |= 1 << 5;
            LPC_RIT->EMR &= ~(1 << 4);
        } else {
            LPC_RIT->EMR |= 1 << 4;
            LPC_RIT->EMR &= ~(1 << 5);
        }
    } else {        //Si on est dans la 2eme demi-periode d'envoie, toggle a la prochaine interruption
        LPC_RIT->EMR |= 3 << 4;
        bit_sent--;
    }
    transmit = !transmit;       //varier entre la 1ere et 2eme partie de demi-periode
    LPC_RIT->MR0 += HALF_PERIOD;    //preparer la prochaine interruption a une demi-periode plus loin
    if (bit_sent < 0) {     //Si l'octet a ete envoye
        bit_sent = 7;       //remettre la position initiale pour le prochain octet
        byte_sent_pos++;    //incrementer l'octet
        if (byte_sent_pos > trame_length) {  //Si la trame a ete envoyee
            LPC_RIT->MCR &= 0;             //desactiver les interruptions du MAT
            LPC_RIT->EMR &= ~(3 << 4);     //remettre a zero le registre EMR (00 pour rien faire, 01 pour mettre a 1, 10 pour mettre a 0 et 11 pour toggle)
            byte_sent_pos = 0;
            transmit = false;
        }
    }
}

void get_text()
{
    CRC16 *myCRC = new CRC16();
    
    trame_sent[0] = 0x55;    //Preambule
    trame_sent[1] = 0x7E;    //Start
    trame_sent[2] = 0x00;    //Type + Flag mis a 0x00
    
    pc.printf("\n\rYour text : ");
    int count = 0;
    char c = 0x00;
    char text[73];
    while(c != 0x0D && count < 73) { //Tant que c'est different de '\r' et un maximum de 33 caractères 
        c = pc.getc();
        trame_sent[count + 4] = c;   //Ajouter les caractères tapés au clavier dans le message
        text[count] = c;
        pc.putc(c);
        count++;
    }
    trame_sent[3] = (char)count;     //Longueur du message (Max 33 caractères)
    
    unsigned short resultCRC = myCRC->calculateCRC16(text,count);     
    trame_sent[count + 4] = (resultCRC >> 8) & 0xFF;
    trame_sent[count + 5] = resultCRC & 0xFF;
    
    trame_sent[count + 6] = 0x7E;    //End
    trame_length = count + 6;        //Longueur de la trame
    
}

void write()
{
    byte_sent_pos = 0;
    bit_sent = 7;
    LPC_RIT->MCR = 1;                      //Permettre les interruption du MAT
    LPC_RIT->MR0 = LPC_RIT->TC + HALF_PERIOD;  //Faire une interruption a la prochaine demi-periode
}

int main() {
    rit_init();
    
    ThreadLecture.start(read);
    
    while(true) {
        get_text();
        write();
        //uart.printf("12345");
        wait_ms(100);
    }
};