Questa è la versione deifinitiva del codice del Lab2_I2C e del lab3_SPI (nell'altra c'era un commento sbagliato è do dovuto ripubblicarla)

Dependencies:   MMA8451Q mbed

Fork of Codice_Lab2_I2C_Lab3_SPI by SDI 2014/2015

Committer:
capopolito
Date:
Tue Jan 20 23:14:42 2015 +0000
Revision:
5:bc92e421d5f8
Parent:
4:c40acfb63133
Child:
6:848474d4d02e
Aggiornamento della precedente

Who changed what in which revision?

UserRevisionLine numberNew contents of line
serenabpolito 0:4317f4b1a4b3 1 #include "mbed.h"
serenabpolito 0:4317f4b1a4b3 2 #include "MMA8451Q.h"
serenabpolito 0:4317f4b1a4b3 3 #include "I2C.h"
capopolito 3:f8f4a33c7aa2 4 #include "SPI.h"
capopolito 3:f8f4a33c7aa2 5 #include "DigitalIn.h"
capopolito 4:c40acfb63133 6 #include "DigitalOut.h"
capopolito 3:f8f4a33c7aa2 7
capopolito 3:f8f4a33c7aa2 8 //--prova--------------------------------------------
capopolito 3:f8f4a33c7aa2 9 //PinName const INT1 = PTA14 ; //pin interrupt
capopolito 3:f8f4a33c7aa2 10 //PinName const INT2 = PTA15 ; //pin interrupt
capopolito 3:f8f4a33c7aa2 11 //--prova--------------------------------------------
serenabpolito 0:4317f4b1a4b3 12
serenabpolito 0:4317f4b1a4b3 13 #if defined (TARGET_KL25Z) || defined (TARGET_KL46Z)
serenabpolito 0:4317f4b1a4b3 14 PinName const SDA = PTE25;
serenabpolito 0:4317f4b1a4b3 15 PinName const SCL = PTE24;
serenabpolito 0:4317f4b1a4b3 16 #elif defined (TARGET_KL05Z)
serenabpolito 0:4317f4b1a4b3 17 PinName const SDA = PTB4;
serenabpolito 0:4317f4b1a4b3 18 PinName const SCL = PTB3;
serenabpolito 0:4317f4b1a4b3 19 #elif defined (TARGET_K20D50M)
serenabpolito 0:4317f4b1a4b3 20 PinName const SDA = PTB1;
serenabpolito 0:4317f4b1a4b3 21 PinName const SCL = PTB0;
serenabpolito 0:4317f4b1a4b3 22 #else
serenabpolito 0:4317f4b1a4b3 23 #error TARGET NOT DEFINED
serenabpolito 0:4317f4b1a4b3 24 #endif
serenabpolito 0:4317f4b1a4b3 25
capopolito 3:f8f4a33c7aa2 26 //--RELATIVI ALLA COMUNICAZIONE SPI------
capopolito 3:f8f4a33c7aa2 27 PinName const mosi = PTD2; //mosi SPI1_mosi
capopolito 3:f8f4a33c7aa2 28 PinName const miso = PTD3; //miso SPI1_miso
capopolito 3:f8f4a33c7aa2 29 PinName const sck = PTD1; //sck SPI1_sck
capopolito 3:f8f4a33c7aa2 30 PinName const pcs0 = PTD0; //pcs0 SPI1_pcs0
capopolito 3:f8f4a33c7aa2 31 //--RELATIVI ALLA COMUNICAZIONE SPI------
serenabpolito 0:4317f4b1a4b3 32
capopolito 3:f8f4a33c7aa2 33 #define MMA8451_I2C_ADDRESS (0x1d<<1)
serenabpolito 0:4317f4b1a4b3 34 //instanzia e inizializza oggettto i2c della clase I2C
serenabpolito 0:4317f4b1a4b3 35 I2C i2c(SDA,SCL); // SDA I2C data line pin
capopolito 3:f8f4a33c7aa2 36 // SCL I2C clock line pin
capopolito 3:f8f4a33c7aa2 37 //--prova------------------------------------------------------------
capopolito 3:f8f4a33c7aa2 38 //instanzia e inizializza oggetti int1 e int2 della classe DigitalIn
capopolito 4:c40acfb63133 39 //DigitalIn int1(INT1); //inizializza int1
capopolito 4:c40acfb63133 40 //DigitalIn int2(INT2); //inizializza int2
capopolito 3:f8f4a33c7aa2 41 //--prova------------------------------------------------------------
serenabpolito 0:4317f4b1a4b3 42
serenabpolito 0:4317f4b1a4b3 43
capopolito 4:c40acfb63133 44 //instanzia e inizializza oggettto spi della classe SPI
capopolito 4:c40acfb63133 45 SPI spi(mosi,miso,sck);
capopolito 4:c40acfb63133 46 DigitalOut slave_select(pcs0,1); //inizializza slave-select
capopolito 4:c40acfb63133 47 //-------------------------------------------------------
capopolito 4:c40acfb63133 48
capopolito 3:f8f4a33c7aa2 49 //registri da impostare
capopolito 2:53521a18c3de 50 char CTRL_REG_1 = 0x2A ; //read/write // register address del CTRL_REG_1
capopolito 2:53521a18c3de 51 char CTRL_REG_2 = 0x2B ; //read/write // register address del CTRL_REG_2
capopolito 2:53521a18c3de 52 char CTRL_REG_3 = 0x2C ; //read/write // register address del CTRL_REG_3
capopolito 2:53521a18c3de 53 char CTRL_REG_4 = 0x2D ; //read/write // register address del CTRL_REG_4
capopolito 2:53521a18c3de 54 char OUT_X_MSB = 0x01 ; //read only // parte più significativa del registro contenete l'accelerazione sull'asse x
capopolito 2:53521a18c3de 55 char OUT_Y_MSB = 0x03 ; //read only // parte più significativa del registro contenete l'accelerazione sull'asse y
capopolito 2:53521a18c3de 56 char OUT_Z_MSB = 0x05 ; //read only // parte più significativa del registro contenete l'accelerazione sull'asse z
capopolito 2:53521a18c3de 57 char XYZ_DATA_CFG = 0x0E; //read/write // register address del XYZ_DATA_CFG
capopolito 2:53521a18c3de 58 char ASLP_COUNT= 0x29; //read/write // register address SLEEP TIME-OUT COUNTER
capopolito 2:53521a18c3de 59 char SYSMOD = 0x0B; //read only // register address SYSMOD System Mode Register
capopolito 4:c40acfb63133 60 //registri da impostare-------------------------------------------------------------------
capopolito 4:c40acfb63133 61
capopolito 4:c40acfb63133 62 //-indirizzo del dipositivo con l'ultimo bit asserito per la lettura e negato per la scrittura
capopolito 3:f8f4a33c7aa2 63 char address_wr = 0x3A ; // byte per eseguire lettura: address_device + bit_wr(W=0)
capopolito 3:f8f4a33c7aa2 64 char address_rd = 0x3B ; // byte per eseguire scrittura: address_device + bit_rd(R=1)
capopolito 4:c40acfb63133 65 //------------------------------------------------------------------------------------------------
capopolito 4:c40acfb63133 66
capopolito 4:c40acfb63133 67 //--variabile di appoggio utilizzata per scrivere e leggere i registri
capopolito 3:f8f4a33c7aa2 68 char data = 0x00 ; // inizalizza la variabile data con le impostazioni da scrivere su CTRL_REG_1
capopolito 3:f8f4a33c7aa2 69
capopolito 3:f8f4a33c7aa2 70 //--registri aggiunti e settati per prova ------------------------------------------------------------------
capopolito 3:f8f4a33c7aa2 71 char CTRL_REG_5 = 0x2E ; //read/write // register address del CTRL_REG_5
capopolito 3:f8f4a33c7aa2 72 char FF_MT_CFG = 0x15; //read/write // registera addres del FF_MT_CFG (Frefall/Motionn Configuration register
capopolito 3:f8f4a33c7aa2 73 char FF_MT_THS = 0x17; //read/write // register address del FF_MT_THS Freefall and Motion Threshold
capopolito 3:f8f4a33c7aa2 74 char FF_MT_COUNT = 0x18; //read/write //register address del FF_MT_COUNT Debounce Register
capopolito 3:f8f4a33c7aa2 75 //--registri aggiunti e settati per prova ---------------------------------------------------------------------
serenabpolito 0:4317f4b1a4b3 76
serenabpolito 0:4317f4b1a4b3 77 int main(void)
serenabpolito 0:4317f4b1a4b3 78 {
capopolito 4:c40acfb63133 79 printf("inizio \n");
capopolito 4:c40acfb63133 80 //--setting delle impostazioni del SPI in base alle specifiche------------------
capopolito 4:c40acfb63133 81 int bits = 8;
capopolito 4:c40acfb63133 82 int mode = 1;
capopolito 4:c40acfb63133 83 spi.format(bits,mode);//definisce formato spi con 16 bit e pol=0 e pha=1
capopolito 4:c40acfb63133 84 //di default la frequenza è 1MHz
capopolito 4:c40acfb63133 85 char command_wr=0x80; //comando per la scrittura (10000DDD), di default nella locazione DDD=000
capopolito 4:c40acfb63133 86 //int command_rd=0; //comando per la lettura (00000DDD), dib default nella locazione DDD=000
capopolito 4:c40acfb63133 87 //non utilizzato !
capopolito 4:c40acfb63133 88 //--setting delle impostazioni della SPI come da specifiche------------------------
serenabpolito 0:4317f4b1a4b3 89
capopolito 4:c40acfb63133 90 //impostazione dei registri dell'I2C con scrittura Single Byte Write
serenabpolito 0:4317f4b1a4b3 91 // setta impostazioni su CTRL_REG_1
capopolito 3:f8f4a33c7aa2 92 data = 0x58 ; // setta la variabile data con le impostazioni da scrivere su CTRL_REG_1
capopolito 2:53521a18c3de 93 //Bit 7-> ASLP_RATE1 = 0
capopolito 2:53521a18c3de 94 //Bit 6-> ASLP_RATE0 = 1 -> // Il sample rate in sleep è 6.25 Hz vedi AN070
capopolito 2:53521a18c3de 95 //Bit 5-> DR2 = 0
capopolito 2:53521a18c3de 96 //Bit 4-> DR1 = 1
capopolito 2:53521a18c3de 97 //Bit 3-> DR0 = 1 -> // Il sample rate in wake è 100 Hz vedi AN070
capopolito 2:53521a18c3de 98 //Bit 2-> LNOISE = 0
capopolito 3:f8f4a33c7aa2 99 //Bit 1-> F_READ = 0 -> //Faste read is enabled, acquissco un solo byte!
capopolito 2:53521a18c3de 100 //Bit 0-> ACTIVE = 0 -> //Mette il dispositivo in standby per settare gli altri registri
serenabpolito 0:4317f4b1a4b3 101 i2c.start(); // dai lo start
serenabpolito 0:4317f4b1a4b3 102 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
serenabpolito 0:4317f4b1a4b3 103 i2c.write(CTRL_REG_1); // scrivi l'indirizzo del CTRL_REG_1
serenabpolito 0:4317f4b1a4b3 104 i2c.write(data); // scrivi il "data" già inizializzato con le impostazioni del CTRL_REG_1
serenabpolito 0:4317f4b1a4b3 105 i2c.stop();
capopolito 3:f8f4a33c7aa2 106 //NOTE:
capopolito 3:f8f4a33c7aa2 107 //La modalità "FAST READ", che si attiva asserendo il bit F_READ, può non essere impostata perchè
capopolito 3:f8f4a33c7aa2 108 //per campionare il dato con risoluzione 8 bit è sufficente leggere solo la parte
capopolito 3:f8f4a33c7aa2 109 //significativa del dato contenuta nei registri OUT_MSB_X, Y e Z.
capopolito 3:f8f4a33c7aa2 110 //Cambio la frequenz di campionamento, valore dell'ODR (Over Sampling Ratio),
capopolito 3:f8f4a33c7aa2 111 //dalla modalità sleep alla modalità wake (in modo da accorgermi di essere in wake)
capopolito 3:f8f4a33c7aa2 112
serenabpolito 0:4317f4b1a4b3 113
serenabpolito 0:4317f4b1a4b3 114 // setta impostazioni su CTRL_REG_2
serenabpolito 0:4317f4b1a4b3 115 data=0x04; //imposta data con le impostazioni del CTRL_REG_2
serenabpolito 0:4317f4b1a4b3 116 //ST=0 disabilita il self-test
serenabpolito 0:4317f4b1a4b3 117 //RST=0 disabilita modalità reset
serenabpolito 0:4317f4b1a4b3 118 //bit 5 don't care
serenabpolito 0:4317f4b1a4b3 119 //SMODS0=SMODS1=0 setta la modalità oversampling_mode = normal , quando è in modalità in sleep
capopolito 2:53521a18c3de 120 //SLPE=1 abilita l'autosleep -> vedi AN070
serenabpolito 0:4317f4b1a4b3 121 //MODS0=MODS1=0 setta la modalità oversampling_mode = normal , quando è in modalità in active
serenabpolito 0:4317f4b1a4b3 122 i2c.start(); // dai lo start
serenabpolito 0:4317f4b1a4b3 123 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
serenabpolito 0:4317f4b1a4b3 124 i2c.write(CTRL_REG_2); // scrivi l'indirizzo del CTRL_REG_2
serenabpolito 0:4317f4b1a4b3 125 i2c.write(data); // scrivi il "data" contenete le impostazioni del CTRL_REG_2
serenabpolito 0:4317f4b1a4b3 126 i2c.stop();
serenabpolito 0:4317f4b1a4b3 127
serenabpolito 0:4317f4b1a4b3 128 // setta impostazioni su CTRL_REG_3
capopolito 3:f8f4a33c7aa2 129 data=0x68; //imposta data con le impostazioni del CTRL_REG_3 attineti alle gestioni dell'interupt in modalità sleep
serenabpolito 0:4317f4b1a4b3 130 // vedi data-sheet
capopolito 1:944348c50dd6 131 //Bit 7-> FIFO GATE = 0
capopolito 3:f8f4a33c7aa2 132 //Bit 6-> WAKE_TRANS = 1
capopolito 3:f8f4a33c7aa2 133 //Bit 5-> WAKE_LNDRPT = 1
capopolito 3:f8f4a33c7aa2 134 //Bit 4-> WAKE_PULSE = 0
capopolito 3:f8f4a33c7aa2 135 //Bit 3-> WAKE_FF_MT = 1
capopolito 1:944348c50dd6 136 //Bit 2-> don't care
capopolito 1:944348c50dd6 137 //Bit 1-> IPOL = 0
capopolito 1:944348c50dd6 138 //Bit 0-> PP_OD = 0
serenabpolito 0:4317f4b1a4b3 139 i2c.start(); // dai lo start
serenabpolito 0:4317f4b1a4b3 140 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
serenabpolito 0:4317f4b1a4b3 141 i2c.write(CTRL_REG_3); // scrivi l'indirizzo del CTRL_REG_3
serenabpolito 0:4317f4b1a4b3 142 i2c.write(data); // scrivi il "data" contenete le impostazioni del CTRL_REG_3
serenabpolito 0:4317f4b1a4b3 143 i2c.stop();
serenabpolito 0:4317f4b1a4b3 144
serenabpolito 0:4317f4b1a4b3 145 // setta impostazioni su CTRL_REG_4
capopolito 3:f8f4a33c7aa2 146 data=0xB5; //imposta data con le impostazioni del CTRL_REG_4 attineti alle gestioni dell'interupt
capopolito 1:944348c50dd6 147 // vedi data-sheet
capopolito 2:53521a18c3de 148 //Bit 7-> IN_EN_ASLP = 1 ; se = 1 Auto-SLEEP/WAKE interrupt enabled -> vedi AN070
capopolito 1:944348c50dd6 149 //Bit 6-> INT_EN_FIFO = 0
capopolito 3:f8f4a33c7aa2 150 //Bit 5-> INT_EN_TRANS = 1
capopolito 3:f8f4a33c7aa2 151 //Bit 4-> INT_EN_LNDPRT = 1
capopolito 3:f8f4a33c7aa2 152 //Bit 3-> INT_EN_PULSE = 0
capopolito 3:f8f4a33c7aa2 153 //Bit 2-> INT_EN_FF_MT = 1
capopolito 1:944348c50dd6 154 //Bit 1-> don't care = 0
capopolito 3:f8f4a33c7aa2 155 //Bit 0-> INT_EN_DRDY = 1 ;// abilito data ready per motivi di logica interna pur no usandolo
serenabpolito 0:4317f4b1a4b3 156 i2c.start(); // dai lo start
serenabpolito 0:4317f4b1a4b3 157 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
serenabpolito 0:4317f4b1a4b3 158 i2c.write(CTRL_REG_4); // scrivi l'indirizzo del CTRL_REG_4
serenabpolito 0:4317f4b1a4b3 159 i2c.write(data); // scrivi il "data" contenete le impostazioni del CTRL_REG_4
serenabpolito 0:4317f4b1a4b3 160 i2c.stop();
capopolito 1:944348c50dd6 161
serenabpolito 0:4317f4b1a4b3 162 // setta impostazioni su XYZ_DATA_CFG
serenabpolito 0:4317f4b1a4b3 163 data=0x00; //imposta data con le impostazioni del XYZ_DATA_CFG attineti alla dinamica che si vuole acquisire (+-2g)
serenabpolito 0:4317f4b1a4b3 164 // FS1=FS0=0 imposta la dinamica +-2g
serenabpolito 0:4317f4b1a4b3 165 i2c.start(); // dai lo start
serenabpolito 0:4317f4b1a4b3 166 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
serenabpolito 0:4317f4b1a4b3 167 i2c.write(XYZ_DATA_CFG); // scrivi l'indirizzo del XYZ_DATA_CFG
serenabpolito 0:4317f4b1a4b3 168 i2c.write(data); // scrivi il "data" contenete le impostazioni del XYZ_DATA_CFG
serenabpolito 0:4317f4b1a4b3 169 i2c.stop();
capopolito 1:944348c50dd6 170
capopolito 3:f8f4a33c7aa2 171 //setta impostazioni su ASLP_COUNT
capopolito 4:c40acfb63133 172 data=0xF0; //->impostato da me valore max
capopolito 3:f8f4a33c7aa2 173 //data=0x01; //impostato da me valore min
capopolito 3:f8f4a33c7aa2 174 //data=0x04; //imposta data con le impostazioni del ASLP_COUNT -> impostato dal professore!!!
capopolito 3:f8f4a33c7aa2 175 i2c.start(); // dai lo start
capopolito 3:f8f4a33c7aa2 176 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 177 i2c.write(ASLP_COUNT); // scrivi l'indirizzo del ASLP_COUNT
capopolito 3:f8f4a33c7aa2 178 i2c.write(data); // scrivi il "data" contenete le impostazioni del ASLP_COUNT
capopolito 3:f8f4a33c7aa2 179 i2c.stop();
capopolito 3:f8f4a33c7aa2 180
capopolito 3:f8f4a33c7aa2 181 //---registri impostati per prova ---------------------------------
capopolito 3:f8f4a33c7aa2 182
capopolito 3:f8f4a33c7aa2 183
capopolito 3:f8f4a33c7aa2 184 // setta impostazioni su CTRL_REG_5
capopolito 3:f8f4a33c7aa2 185 data=0x81; //imposta data con le impostazioni del CTRL_REG_5 attineti alle gestioni dell'interupt nei pin
capopolito 3:f8f4a33c7aa2 186 // vedi data-sheet
capopolito 3:f8f4a33c7aa2 187 //Bit 7-> INT_CFG_ASLP = 1 route the auto-sleep interrupt to INT1 ->vedi AN074
capopolito 3:f8f4a33c7aa2 188 //Bit 6-> INT_CFG_FIFO = 0
capopolito 3:f8f4a33c7aa2 189 //Bit 5-> INT_CFG_TRANS = 0
capopolito 3:f8f4a33c7aa2 190 //Bit 4-> INT_CFG_LNDPRT = 0
capopolito 3:f8f4a33c7aa2 191 //Bit 3-> INT_CFG_PULSE = 0 route the pulse interrupt to INT2 ->vedi AN074
capopolito 3:f8f4a33c7aa2 192 //Bit 2-> INT_CFG_FF_MT = 0 route the Motion and Orientation interrupt to INT2 ->vedi AN074
capopolito 3:f8f4a33c7aa2 193 //Bit 1-> DON'T CARE = 0
capopolito 3:f8f4a33c7aa2 194 //Bit 0-> INT_CFG_DRDY = 1 route the data-ready interrupt to INT1 ->vedi AN074
capopolito 3:f8f4a33c7aa2 195 i2c.start(); // dai lo start
capopolito 3:f8f4a33c7aa2 196 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 197 i2c.write(CTRL_REG_5); // scrivi l'indirizzo del CTRL_REG_5
capopolito 3:f8f4a33c7aa2 198 i2c.write(data); // scrivi il "data" contenete le impostazioni del CTRL_REG_5
capopolito 3:f8f4a33c7aa2 199 i2c.stop();
capopolito 3:f8f4a33c7aa2 200
capopolito 1:944348c50dd6 201 // setta impostazioni su FF_MT_CFG (Frefall/Motion Configuration Register (Read/Write)
capopolito 3:f8f4a33c7aa2 202 data=0xF8; //imposta data con le impostazioni del FF_MT_SRC attineti quando vogliamo svegliare il dispositivo dal wake
capopolito 1:944348c50dd6 203 //Bit 7-> ELE = 1 ;event flag latch enabled in FF_MT_SRC
capopolito 3:f8f4a33c7aa2 204 //Bit 6-> OAE = 1 ;Motion Flag (if=1 OR combination) (if=1 AND combination)
capopolito 1:944348c50dd6 205 //Bit 5-> ZEFE = 1 ;se = 0 asse Z event dection disabled ; se = 1 asse X raise event flag on measured acceleration value beyond present threshold
capopolito 1:944348c50dd6 206 //Bit 4-> YEFE = 1 ;se = 0 asse Y event dection disabled ; se = 1 asse Y raise event flag on measured acceleration value beyond present threshold
capopolito 1:944348c50dd6 207 //Bit 3-> XEFE = 1 ;se = 0 asse X event dection disabled ; se = 1 asse X raise event flag on measured acceleration value beyond present threshold
capopolito 1:944348c50dd6 208 //Bit 2-> = 0 don't care
capopolito 1:944348c50dd6 209 //Bit 1-> = 0 don't care
capopolito 1:944348c50dd6 210 //Bit 0-> = 0 don't care
capopolito 1:944348c50dd6 211 i2c.start(); // dai lo start
capopolito 1:944348c50dd6 212 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 1:944348c50dd6 213 i2c.write(FF_MT_CFG); // scrivi l'indirizzo del FF_MT_CFG
capopolito 1:944348c50dd6 214 i2c.write(data); // scrivi il "data" contenete le impostazioni del FF_MT_CFG
capopolito 1:944348c50dd6 215 i2c.stop();
capopolito 3:f8f4a33c7aa2 216
capopolito 3:f8f4a33c7aa2 217
capopolito 3:f8f4a33c7aa2 218 // setta impostazioni su FF_MT_THS (Read/Write)
capopolito 3:f8f4a33c7aa2 219 data=0x04; //imposta data con le impostazioni del FF_MT_THS
capopolito 2:53521a18c3de 220 i2c.start(); // dai lo start
capopolito 2:53521a18c3de 221 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 222 i2c.write(FF_MT_THS); // scrivi l'indirizzo del FF_MT_THS
capopolito 3:f8f4a33c7aa2 223 i2c.write(data); // scrivi il "data" contenete le impostazioni del FF_MT_THS
capopolito 3:f8f4a33c7aa2 224 i2c.stop();
capopolito 3:f8f4a33c7aa2 225
capopolito 3:f8f4a33c7aa2 226 // setta impostazioni su FF_MT_COUNT (Read/Write)
capopolito 3:f8f4a33c7aa2 227 data=0x08; //imposta data con le impostazioni del FF_MT_COUNT
capopolito 3:f8f4a33c7aa2 228 i2c.start(); // dai lo start
capopolito 3:f8f4a33c7aa2 229 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 230 i2c.write(FF_MT_COUNT); // scrivi l'indirizzo del FF_MT_COUNT
capopolito 3:f8f4a33c7aa2 231 i2c.write(data); // scrivi il "data" contenete le impostazioni del FF_MT_COUNT
capopolito 2:53521a18c3de 232 i2c.stop();
capopolito 1:944348c50dd6 233
capopolito 3:f8f4a33c7aa2 234 //---registri impostati per prova ---------------------------------
capopolito 3:f8f4a33c7aa2 235
capopolito 3:f8f4a33c7aa2 236
capopolito 2:53521a18c3de 237 //!!! attiva il dispositivo (esce da standby) !!!
serenabpolito 0:4317f4b1a4b3 238 // setta impostazioni su CTRL_REG_1
capopolito 3:f8f4a33c7aa2 239 data=0x5B ; // mette a 1 il bit ACTIVE e lascia invariati gli altri (già impostati)
capopolito 3:f8f4a33c7aa2 240 i2c.start(); // dai lo start
serenabpolito 0:4317f4b1a4b3 241 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
serenabpolito 0:4317f4b1a4b3 242 i2c.write(CTRL_REG_1); // scrivi l'indirizzo del CTRL_REG_1
capopolito 3:f8f4a33c7aa2 243 i2c.write(data); // scrivi il "data" in le impostazioni del CTRL_REG_1
serenabpolito 0:4317f4b1a4b3 244 i2c.stop();
serenabpolito 0:4317f4b1a4b3 245
capopolito 3:f8f4a33c7aa2 246 //PER ACCENDERE LED
serenabpolito 0:4317f4b1a4b3 247 PwmOut rled(LED1);
serenabpolito 0:4317f4b1a4b3 248 PwmOut gled(LED2);
capopolito 1:944348c50dd6 249 PwmOut bled(LED3);
capopolito 1:944348c50dd6 250
capopolito 3:f8f4a33c7aa2 251 //verifica della corretta scrittura dei registri, mediante lettura Single Byte Read
capopolito 2:53521a18c3de 252
capopolito 3:f8f4a33c7aa2 253 //lettura single byte read del registro CTRL_REG_1
capopolito 3:f8f4a33c7aa2 254 char ctrl_reg_1 = 0x00;
capopolito 2:53521a18c3de 255 i2c.start();
capopolito 3:f8f4a33c7aa2 256 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 2:53521a18c3de 257 i2c.write(CTRL_REG_1); // scrivi l'indirizzo del registro
capopolito 2:53521a18c3de 258 i2c.start();
capopolito 3:f8f4a33c7aa2 259 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 2:53521a18c3de 260 ctrl_reg_1=i2c.read(0);
capopolito 2:53521a18c3de 261 i2c.stop();
capopolito 3:f8f4a33c7aa2 262 printf("CTRL_REG_1: %1.2x \n", ctrl_reg_1); // in esadecimale
capopolito 2:53521a18c3de 263
capopolito 3:f8f4a33c7aa2 264 //lettura single byte read del registro CTRL_REG_2
capopolito 2:53521a18c3de 265 char ctrl_reg_2 = 0x00;
capopolito 2:53521a18c3de 266 i2c.start();
capopolito 3:f8f4a33c7aa2 267 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 2:53521a18c3de 268 i2c.write(CTRL_REG_2); // scrivi l'indirizzo del registro
capopolito 2:53521a18c3de 269 i2c.start();
capopolito 3:f8f4a33c7aa2 270 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 2:53521a18c3de 271 ctrl_reg_2=i2c.read(0);
capopolito 2:53521a18c3de 272 i2c.stop();
capopolito 3:f8f4a33c7aa2 273 printf("CTRL_REG_2: %1.2x \n", ctrl_reg_2); //in esadecimale
capopolito 2:53521a18c3de 274
capopolito 2:53521a18c3de 275 //lettura single byte read del registro CTRL_REG_3
capopolito 3:f8f4a33c7aa2 276 char ctrl_reg_3 = 0x00;
capopolito 2:53521a18c3de 277 i2c.start();
capopolito 3:f8f4a33c7aa2 278 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 2:53521a18c3de 279 i2c.write(CTRL_REG_3); // scrivi l'indirizzo del registro
capopolito 2:53521a18c3de 280 i2c.start();
capopolito 3:f8f4a33c7aa2 281 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 2:53521a18c3de 282 ctrl_reg_3=i2c.read(0);
capopolito 2:53521a18c3de 283 i2c.stop();
capopolito 3:f8f4a33c7aa2 284 printf("CTRL_REG_3: %1.2x \n", ctrl_reg_3); //in esadecimale
capopolito 2:53521a18c3de 285
capopolito 3:f8f4a33c7aa2 286 //lettura single byte read del registro CTRL_REG_4
capopolito 2:53521a18c3de 287 char ctrl_reg_4 = 0x00;
capopolito 2:53521a18c3de 288 i2c.start();
capopolito 3:f8f4a33c7aa2 289 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 2:53521a18c3de 290 i2c.write(CTRL_REG_4); // scrivi l'indirizzo del registro
capopolito 2:53521a18c3de 291 i2c.start();
capopolito 3:f8f4a33c7aa2 292 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 2:53521a18c3de 293 ctrl_reg_4=i2c.read(0);
capopolito 2:53521a18c3de 294 i2c.stop();
capopolito 3:f8f4a33c7aa2 295 printf("CTRL_REG_4: %1.2x \n", ctrl_reg_4); //in esadecimale
capopolito 3:f8f4a33c7aa2 296
capopolito 3:f8f4a33c7aa2 297 //lettura single byte read del registro ASLP_COUNT
capopolito 3:f8f4a33c7aa2 298 char aslp_count = 0x00;
capopolito 2:53521a18c3de 299 i2c.start();
capopolito 3:f8f4a33c7aa2 300 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 2:53521a18c3de 301 i2c.write(ASLP_COUNT); // scrivi l'indirizzo del registro
capopolito 2:53521a18c3de 302 i2c.start();
capopolito 3:f8f4a33c7aa2 303 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 2:53521a18c3de 304 aslp_count=i2c.read(0);
capopolito 2:53521a18c3de 305 i2c.stop();
capopolito 3:f8f4a33c7aa2 306 printf("ASLP_COUNT: %1.2x \n", aslp_count); //in esadecimale
capopolito 3:f8f4a33c7aa2 307
capopolito 2:53521a18c3de 308 char sysmod = 0x00;
capopolito 4:c40acfb63133 309
capopolito 4:c40acfb63133 310 float x_axis, y_axis, z_axis;
capopolito 4:c40acfb63133 311 float x_axis_norm, y_axis_norm, z_axis_norm;
capopolito 4:c40acfb63133 312 int x_tens, x_unit, y_tens, y_unit, z_tens, z_unit;
capopolito 4:c40acfb63133 313 char x_tens_ascii, x_unit_ascii, y_tens_ascii, y_unit_ascii, z_tens_ascii, z_unit_ascii;
capopolito 4:c40acfb63133 314 char loc_x_tens=0x00, loc_x_unit=0x01, loc_y_tens=0x02, loc_y_unit=0x03, loc_z_tens=0x04, loc_z_unit=0x05;
capopolito 4:c40acfb63133 315 //location DDD=000, DDD=001, DDD=010, DDD=011, DDD=100, DDD=101;
capopolito 4:c40acfb63133 316
capopolito 4:c40acfb63133 317 char command_location=0x00; // in caso di scrittura 1000 DDD
capopolito 4:c40acfb63133 318
capopolito 3:f8f4a33c7aa2 319 //int int1_value = 0;
capopolito 3:f8f4a33c7aa2 320 //int int2_value = 0;
serenabpolito 0:4317f4b1a4b3 321 while (true) {
capopolito 3:f8f4a33c7aa2 322 printf("SYSMOD_pre_read: %1.2x \n", sysmod);
capopolito 3:f8f4a33c7aa2 323 wait(0.1);
capopolito 3:f8f4a33c7aa2 324 //lettura dello stato dell'accelerometro wake o sleep
capopolito 3:f8f4a33c7aa2 325 // lettura single Byte Read contenuto di SYSMOD System Mode Register
capopolito 3:f8f4a33c7aa2 326 // Bit 7-> FGERR
capopolito 3:f8f4a33c7aa2 327 // Bit 6-> FGT_4
capopolito 3:f8f4a33c7aa2 328 // Bit 5-> FGT_3
capopolito 3:f8f4a33c7aa2 329 // Bit 4-> FGT_2
capopolito 3:f8f4a33c7aa2 330 // Bit 3-> FGT_1
capopolito 3:f8f4a33c7aa2 331 // Bit 2-> FGT_0
capopolito 3:f8f4a33c7aa2 332 // Bit 1-> SYSMOD1
capopolito 3:f8f4a33c7aa2 333 // Bit 0-> SYSMOD0
capopolito 3:f8f4a33c7aa2 334 // SYSMOD[1:0]
capopolito 3:f8f4a33c7aa2 335 // System Mode. Default value: 00.
capopolito 3:f8f4a33c7aa2 336 // 00: STANDBY mode
capopolito 3:f8f4a33c7aa2 337 // 01: WAKE mode
capopolito 3:f8f4a33c7aa2 338 // 10: SLEEP mode
capopolito 1:944348c50dd6 339 i2c.start();
capopolito 3:f8f4a33c7aa2 340 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 341 i2c.write(SYSMOD); // scrivi l'indirizzo del registro
capopolito 1:944348c50dd6 342 i2c.start();
capopolito 3:f8f4a33c7aa2 343 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 2:53521a18c3de 344 sysmod=i2c.read(0);
capopolito 2:53521a18c3de 345 i2c.stop();
capopolito 3:f8f4a33c7aa2 346 printf("SYSMOD_post_read: %1.2x \n", sysmod);
capopolito 2:53521a18c3de 347 wait(0.1f);
capopolito 3:f8f4a33c7aa2 348 if ( (sysmod &0x02) == 0x02) { // if SYSMOD1,SYSMOD0 = 1,0
capopolito 3:f8f4a33c7aa2 349 wait(0.1f);
capopolito 3:f8f4a33c7aa2 350 printf("I'm sleeping , SYSMOD: %1.2x \n",sysmod);
capopolito 3:f8f4a33c7aa2 351 rled = 0.0f;
capopolito 3:f8f4a33c7aa2 352 gled = 0.0f;
capopolito 3:f8f4a33c7aa2 353 bled = 0.0f;
capopolito 3:f8f4a33c7aa2 354 //---prova------------------------------------------------
capopolito 3:f8f4a33c7aa2 355 //mette il dispositivo in standby
capopolito 3:f8f4a33c7aa2 356 //setta impostazioni su CTRL_REG_1
capopolito 3:f8f4a33c7aa2 357 data=0x5A ; // mette a 1 il bit ACTIVE e lascia invariati gli altri (già impostati)
capopolito 3:f8f4a33c7aa2 358 i2c.start(); // dai lo start
capopolito 3:f8f4a33c7aa2 359 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 360 i2c.write(CTRL_REG_1); // scrivi l'indirizzo del CTRL_REG_1
capopolito 3:f8f4a33c7aa2 361 i2c.write(data); // scrivi il "data" in le impostazioni del CTRL_REG_1
capopolito 3:f8f4a33c7aa2 362 i2c.stop();
capopolito 3:f8f4a33c7aa2 363 //attiva il dispositivo
capopolito 3:f8f4a33c7aa2 364 //setta impostazioni su CTRL_REG_1
capopolito 3:f8f4a33c7aa2 365 data=0x5B ; // mette a 1 il bit ACTIVE e lascia invariati gli altri (già impostati)
capopolito 3:f8f4a33c7aa2 366 i2c.start(); // dai lo start
capopolito 3:f8f4a33c7aa2 367 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 368 i2c.write(CTRL_REG_1); // scrivi l'indirizzo del CTRL_REG_1
capopolito 3:f8f4a33c7aa2 369 i2c.write(data); // scrivi il "data" in le impostazioni del CTRL_REG_1
capopolito 3:f8f4a33c7aa2 370 i2c.stop();
capopolito 3:f8f4a33c7aa2 371 //int1_value=int1.read();
capopolito 3:f8f4a33c7aa2 372 //int2_value=int2.read();
capopolito 3:f8f4a33c7aa2 373 //printf("INT1_sleep: %1.2d \n",INT1);
capopolito 3:f8f4a33c7aa2 374 //printf("INT2_sleep: %1.2d \n",INT2);
capopolito 3:f8f4a33c7aa2 375 //---prova------------------------------------------------
capopolito 3:f8f4a33c7aa2 376
capopolito 2:53521a18c3de 377 } //chiusra del if
capopolito 3:f8f4a33c7aa2 378 if ( (sysmod &0x01) ==0x01){ // if SYSMOD1,SYSMOD0 = 0,1
capopolito 3:f8f4a33c7aa2 379 //---prova-------------------------------------------------
capopolito 3:f8f4a33c7aa2 380 //int1_value=int1.read;
capopolito 3:f8f4a33c7aa2 381 //int2_value=int2.read;
capopolito 3:f8f4a33c7aa2 382 //printf("INT1_wake: %1.2d \n",INT1);
capopolito 3:f8f4a33c7aa2 383 //printf("INT2_wake: %1.2d \n",INT2);
capopolito 3:f8f4a33c7aa2 384 //---prova-------------------------------------------------
capopolito 3:f8f4a33c7aa2 385 wait(0.1f);
capopolito 3:f8f4a33c7aa2 386 printf("Good morning! , SYSMOD: %1.2x \n", sysmod);
capopolito 3:f8f4a33c7aa2 387 //lettura degli assi con lettura Single Byte Read
capopolito 3:f8f4a33c7aa2 388 // asse x
capopolito 3:f8f4a33c7aa2 389 i2c.start();
capopolito 3:f8f4a33c7aa2 390 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 391 i2c.write(OUT_X_MSB); // scrivi l'indirizzo del registro contente l'accelerazione sull'asse X
capopolito 3:f8f4a33c7aa2 392 i2c.start();
capopolito 3:f8f4a33c7aa2 393 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 3:f8f4a33c7aa2 394 x_axis=i2c.read(0); // scrive bit di NAK (non acknowlodgement) e salva il dato sul bus su x_axis
capopolito 3:f8f4a33c7aa2 395 i2c.stop();
capopolito 3:f8f4a33c7aa2 396 // asse y
capopolito 3:f8f4a33c7aa2 397 i2c.start();
capopolito 3:f8f4a33c7aa2 398 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 399 i2c.write(OUT_Y_MSB); // scrivi l'indirizzo del registro contente l'accelerazione sull'asse Y
capopolito 3:f8f4a33c7aa2 400 i2c.start();
capopolito 3:f8f4a33c7aa2 401 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 3:f8f4a33c7aa2 402 y_axis=i2c.read(0); // scrive bit di NAK (non acknowlodgement) e salva il dato sul bus su y_axis
capopolito 3:f8f4a33c7aa2 403 i2c.stop();
capopolito 3:f8f4a33c7aa2 404 // asse Z
capopolito 3:f8f4a33c7aa2 405 i2c.start();
capopolito 3:f8f4a33c7aa2 406 i2c.write(address_wr); // scrivi e passa l'indirizzo del dispositivo con bit di scrittura
capopolito 3:f8f4a33c7aa2 407 i2c.write(OUT_Z_MSB); // scrivi l'indirizzo del registro contente l'accelerazione sull'asse Z
capopolito 3:f8f4a33c7aa2 408 i2c.start();
capopolito 3:f8f4a33c7aa2 409 i2c.write(address_rd); // scrivi e passa l'indirizzo del dispositivo con bit di read
capopolito 3:f8f4a33c7aa2 410 z_axis=i2c.read(0); // scrive bit di NAK (non acknowlodgement) e salva il dato sul bus su z_axis
capopolito 3:f8f4a33c7aa2 411 i2c.stop();
capopolito 3:f8f4a33c7aa2 412 //accendo led
capopolito 4:c40acfb63133 413 rled = 1.0f - x_axis/64;
capopolito 4:c40acfb63133 414 gled = 1.0f - y_axis/64;
capopolito 4:c40acfb63133 415 bled = 1.0f - z_axis/64;
capopolito 3:f8f4a33c7aa2 416 //scrivo sulla seriale
capopolito 3:f8f4a33c7aa2 417 printf("X: %1.2f, Y: %1.2f, Z: %1.2f\n", x_axis/64, y_axis/64, z_axis/64);
capopolito 3:f8f4a33c7aa2 418
capopolito 4:c40acfb63133 419 //SCRIVO DATI SU DISPLAY A SETTE SEGMENTI DELLA SCHEDA DE2 MEDIANTE SPI
capopolito 4:c40acfb63133 420 //accelerazione sull'asse x
capopolito 4:c40acfb63133 421 x_axis_norm=x_axis/64*99; // normalizzo tra [0 99]
capopolito 4:c40acfb63133 422 x_tens = (int(x_axis_norm/10)); // ottengo le decine
capopolito 4:c40acfb63133 423 x_unit = (x_axis_norm-10*x_tens); // ottengo le unità
capopolito 4:c40acfb63133 424 x_tens_ascii = ( '0' + (x_tens) ); // ottengo le decine in ASCII
capopolito 4:c40acfb63133 425 x_unit_ascii = ( '0' + (x_unit) ); // ottengo le unità in ASCII
capopolito 4:c40acfb63133 426 //accelerazione sull'asse y
capopolito 4:c40acfb63133 427 y_axis_norm=y_axis/64*99; // normalizzo tra [0 99]
capopolito 4:c40acfb63133 428 y_tens = (int(y_axis_norm/10)); // ottengo le decine
capopolito 4:c40acfb63133 429 y_unit = (y_axis_norm-10*y_tens); // ottengo le unità
capopolito 4:c40acfb63133 430 y_tens_ascii = ( '0' + (y_tens) ); // ottengo le decine in ASCII
capopolito 4:c40acfb63133 431 y_unit_ascii = ( '0' + (y_unit) ); // ottengo le unità in ASCII
capopolito 4:c40acfb63133 432 //accelerazione sull'asse z
capopolito 4:c40acfb63133 433 z_axis_norm=z_axis/64*99; // normalizzo tra [0 99]
capopolito 4:c40acfb63133 434 z_tens = (int(z_axis_norm/10)); // ottengo le decine
capopolito 4:c40acfb63133 435 z_unit = (z_axis_norm-10*z_tens); // ottengo le unità
capopolito 4:c40acfb63133 436 z_tens_ascii = ( '0' + (z_tens) ); // ottengo le decine in ASCII
capopolito 4:c40acfb63133 437 z_unit_ascii = ( '0' + (z_unit) ); // ottengo le unità in ASCII
capopolito 4:c40acfb63133 438
capopolito 4:c40acfb63133 439 //stampo nella seriale componente x,y,z dell'accelereazione normailzzate tra 0 e 99
capopolito 4:c40acfb63133 440 printf("ax_norm: %1.2f, ay_norm: %1.2f, az_norm: %1.2f\n", x_axis_norm, y_axis_norm, z_axis_norm);
capopolito 4:c40acfb63133 441 //stampo nella seriale le decine delle componenti x,y,z dell'accelereazione normailzzate tra 0 e 99
capopolito 4:c40acfb63133 442 printf("ax_tens: %1.2d, ay_tens: %1.2d, az_tens: %1.2d\n", x_tens, y_tens, z_tens);
capopolito 4:c40acfb63133 443 //stampo nella seriale le unità delle componenti x,y,z dell'accelereazione normailzzate tra 0 e 99
capopolito 4:c40acfb63133 444 printf("ax_unit: %1.2d, ay_unit: %1.2d, az_unit: %1.2d\n", x_unit, y_unit, z_unit);
capopolito 4:c40acfb63133 445 //stampo nella seriale le decine in ascii delle componenti x,y,z dell'accelereazione normailzzate tra 0 e 99
capopolito 4:c40acfb63133 446 printf("ax_tens_ascii: %1.2c, ay_tens_ascii: %1.2c, az_tens_ascii: %1.2c\n", x_tens_ascii, y_tens_ascii, z_tens_ascii);
capopolito 4:c40acfb63133 447 //stampo nella seriale le unità in ascii delle componenti x,y,z dell'accelereazione normailzzate tra 0 e 99
capopolito 4:c40acfb63133 448 printf("ax_unit_ascii: %1.2c, ay_unit_ascii: %1.2c, az_unit_ascii: %1.2c\n", x_unit_ascii, y_unit_ascii, z_unit_ascii);
capopolito 4:c40acfb63133 449
capopolito 4:c40acfb63133 450 //scrivo nei display i valori dell'accelerazione
capopolito 3:f8f4a33c7aa2 451
capopolito 4:c40acfb63133 452 //componente x dell'accelarazione
capopolito 4:c40acfb63133 453 //scrivo codice ascii delle decine nel display nel display dedicato
capopolito 5:bc92e421d5f8 454 command_location = ( command_wr | loc_x_tens ) ; //1000 000 = 0x80
capopolito 5:bc92e421d5f8 455 //command_location = 0x80;
capopolito 4:c40acfb63133 456 slave_select.write(0);
capopolito 4:c40acfb63133 457 spi.write(command_location);
capopolito 4:c40acfb63133 458 spi.write(x_tens_ascii);
capopolito 4:c40acfb63133 459 slave_select.write(1);
capopolito 4:c40acfb63133 460 //scrivo codice ascii delle unità nel display nel display dedicato
capopolito 5:bc92e421d5f8 461 command_location = command_wr | loc_x_unit ; //1000 001 = 0x81
capopolito 5:bc92e421d5f8 462 //command_location = 0x81;
capopolito 4:c40acfb63133 463 slave_select.write(0);
capopolito 4:c40acfb63133 464 spi.write(command_location);
capopolito 4:c40acfb63133 465 spi.write(x_unit_ascii);
capopolito 4:c40acfb63133 466 slave_select.write(1);
capopolito 4:c40acfb63133 467
capopolito 4:c40acfb63133 468 //componente y dell'accelarazione
capopolito 4:c40acfb63133 469 //scrivo codice ascii delle decine nel display nel display dedicato
capopolito 5:bc92e421d5f8 470 command_location = command_wr | loc_y_tens ; //1000 010 = 0x82
capopolito 5:bc92e421d5f8 471 //command_location = 0x82;
capopolito 4:c40acfb63133 472 slave_select.write(0); //asserisco lo slave select attivo basso
capopolito 4:c40acfb63133 473 spi.write(command_location);
capopolito 4:c40acfb63133 474 spi.write(y_tens_ascii);
capopolito 4:c40acfb63133 475 slave_select.write(1); //nego lo slave select attivo basso
capopolito 4:c40acfb63133 476 //scrivo codice ascii delle unità nel display nel display dedicato
capopolito 5:bc92e421d5f8 477 command_location = command_wr | loc_y_unit ; //1000 011 = 0x83
capopolito 5:bc92e421d5f8 478 //command_location = 0x83;
capopolito 4:c40acfb63133 479 slave_select.write(0); //asserisco lo slave select attivo basso
capopolito 4:c40acfb63133 480 spi.write(command_location);
capopolito 4:c40acfb63133 481 spi.write(y_unit_ascii);
capopolito 4:c40acfb63133 482 slave_select.write(1); //nego lo slave select attivo basso
capopolito 4:c40acfb63133 483
capopolito 4:c40acfb63133 484 //componente z dell'accelarazione
capopolito 4:c40acfb63133 485 //scrivo codice ascii delle decine nel display nel display dedicato
capopolito 5:bc92e421d5f8 486 command_location = command_wr | loc_z_tens ; //1000 100 = 0x84
capopolito 5:bc92e421d5f8 487 //command_location = 0x84;
capopolito 4:c40acfb63133 488 slave_select.write(0); //asserisco lo slave select attivo basso
capopolito 4:c40acfb63133 489 spi.write(command_location);
capopolito 4:c40acfb63133 490 spi.write(z_tens_ascii);
capopolito 4:c40acfb63133 491 slave_select.write(1); //nego lo slave select attivo basso
capopolito 4:c40acfb63133 492 //scrivo codice ascii delle unità nel display nel display dedicato
capopolito 5:bc92e421d5f8 493 command_location = command_wr | loc_z_unit ; //1000 101 = 0x85
capopolito 5:bc92e421d5f8 494 //command_location = 0x85;
capopolito 4:c40acfb63133 495 slave_select.write(0);
capopolito 4:c40acfb63133 496 spi.write(command_location);
capopolito 4:c40acfb63133 497 spi.write(z_unit_ascii);
capopolito 4:c40acfb63133 498 slave_select.write(1);
capopolito 4:c40acfb63133 499
capopolito 3:f8f4a33c7aa2 500 } //close 2nd if
capopolito 3:f8f4a33c7aa2 501 }//close while
capopolito 3:f8f4a33c7aa2 502 }//close main
serenabpolito 0:4317f4b1a4b3 503