sakthi priya amirtharaj
/
BAE_NEW_VR_0_0
not workin
Fork of BAE_FRDM_INTEGRATION by
Diff: slave.cpp
- Revision:
- 9:6bcc165ee457
- Parent:
- 8:667fbc82d634
--- a/slave.cpp Mon Dec 15 05:58:23 2014 +0000 +++ b/slave.cpp Tue Dec 16 11:37:09 2014 +0000 @@ -113,16 +113,12 @@ //DigitalOut data_ready(D10); //Again in the main function //int i2c_status=0; //read/write mode for i2c 0 : write2slave, 1 : write2master (Again in tha main) -typedef struct -{ - char data; // To avoid dynamic memory allocation - int length; -}i2c_data; + //Mail<i2c_data,16> i2c_data_receive; To be done in the main //Mail<i2c_data,16> i2c_data_send; To be done in the main -void FUNC_I2C_WRITE2CDMS(char *data, int length=1) +void FUNC_I2C_WRITE2CDMS(char *data, int length) { int slave_status = 1; @@ -157,61 +153,12 @@ } -/*void T_I2C_BAE(void const * args) -{ - char data_send,data_receive; - //data_send = 'a'; - while(1) - { - Thread::signal_wait(0x1); - printf("\ndetected interrupt\n"); - if(i2c_status == 0) - { - - FUNC_I2C_WRITE2CDMS(&data_receive); - //printf("\n Data received from CDMS is %c\n",data_receive); - i2c_data * i2c_data_r = i2c_data_receive.alloc(); - i2c_data_r->data = data_receive; - i2c_data_r->length = 1; - i2c_data_receive.put(i2c_data_r); - } - else if(i2c_status ==1 ) - { - osEvent evt = i2c_data_send.get(); - if (evt.status == osEventMail) - { - i2c_data *i2c_data_s = (i2c_data*)evt.value.p; - //printf("\nData read from CDMS is %c\n",i2c_data_r->data); - data_send = i2c_data_s -> data; - FUNC_I2C_WRITE2CDMS(&data_send); - printf("\nData sent to CDMS is %c\n",data_send); - i2c_data_send.free(i2c_data_s); - i2c_status = 0; - //delete i2c_data_r; - } - } - } -} -void FUNC_INT() -{ - // char * data = new char; - //*data = 'a'; - //printf("\nInterrupt from master detected\n"); - ptr_t_i2c->signal_set(0x1); - // - //delete data; -} + -void main() -{ - printf("\nStarted slave... waiting for master\n"); - ptr_t_i2c = new Thread(T_I2C_BAE); - char data='a'; - interrupt.rise(&FUNC_INT); - + /* i2c_data * i2c_data_s = i2c_data_send.alloc(); i2c_data_s->data = data; i2c_data_s->length = 1;