cīnās ar to, kas, iespējams, ir vienkāršs koda fragments, lai kopētu 2 baitus, kas saņemti no I2C vergu, masīvā, lai pēc tam varētu konvertēt uz INT un veikt datu matemātiku.
Šis kods veiksmīgi (saskaņā ar manu I2C analizatoru) nolasa 2 secīgus baitus no vienas reģistra adreses 16 bitu ADC.
void ADC_Initialise( void )
{
_DINT() ; // disable all maskable interrupts
I2C_SCL_HIGH() ;
I2C_SCL_OUTPUT() ;
I2C_SDA_HIGH() ;
I2C_SDA_OUTPUT() ;
I2C_Write_Register_3B( ADC, 0x01, 0xC0, 0x83) ; // Write 2 bytes to ADC Config Register
for(i=0; i < 10000; i++);
I2C_Read_Register( ADC, 0x00 ); // Read the 2 byte ADC value
for(i=0; i < 10000; i++);
_EINT() ; // re-enable the interrupts
}
static unsigned char I2C_Read_Register( char Device_Address, char Register_Address )
{
unsigned char Value ;
I2CM_Start( ) ;
if( I2CM_Out( Device_Address << 1 ) ) //send write control byte + chip address
return 0 ;
else if( I2CM_Out( Register_Address ) ) //send register number
return 0 ;
I2CM_Start( ) ; // Restart
if( I2CM_Out(( Device_Address << 1 ) | 0x01 )) //send read control byte + chip address
return 0 ;
I2CM_In( &Value, 2 ) ; //RJ 6.8.19 input 2 byte ADC value to 'buf'
// return Value ; //rj placed after IC2M_In
I2CM_Stop( ) ;
return Value ; //rj placed after IC2M_Stop
}
static void I2CM_In( unsigned char* buf, int count )
{
unsigned char data ;
for( ; count--; ) // How do I store these 2 bytes in a char[] or INT
{
data = 0 ;
I2C_SDA_INPUT() ;
volatile unsigned int i = 0 ;
for( ; i < 8 ; ++i )
{
//Set Clock High
I2C_SCL_HIGH() ;
//shift the bit over
data <<= 1 ;
if( I2C_SDA_IS_HIGH() )
{
data |= 0x01 ;
}
//Set Clock Low
brief_pause( 0x04 ) ;
I2C_SCL_LOW() ;
}
//put the input data byte into the buffer, inc buffer pointer
*buf++ = data ;
//take sda to output ack
I2C_SDA_OUTPUT() ;
//Set Clock High
I2C_SCL_HIGH() ;
//Set Clock Low
brief_pause( 0x04 ) ;
I2C_SCL_LOW() ;
}
}
Tātad, iespējams, man ir nepieciešams masīvs (neparakstīts char adcarray [2], lai savāktu / saglabātu iegūtos lasījumus, tāpēc es mēģināju -
*buf++ = data ;
adcarray[] = data ;
adcarray[] = buf ;
“Sagaidāma izteiksme”, iespējams, nozīmē, ka man ir nepieciešama kāda for cilpa, lai aizpildītu masīvu katrā piegājienā, lai gan *buf līnija jau atrodas 2. skaitīšanas cilpas iekšpusē.
Palīdzība tiek novērtēta (C IAR uz MSP430 un ADS1115 ADC). Ar cieņu, Ralf
adcarray
vaiValue
— jūs esat izlaidis šo mainīgo deklarācijas. - person Chris Turner   schedule 07.08.2019Value
? Tajā jāietver 2 baiti, ko nolasa “I2CM_In. What's wrong with the content of
Value”? Vai tas atšķiras no tā, ko redzat savā analizatorā? - person Gerhardh   schedule 07.08.2019unsigned char Value;
Kā tam vajadzētu ietilpt 2 baitus? - person Gerhardh   schedule 07.08.2019buf
irValue
, kas piešķir tikai baitu atmiņas. Vērtībai, iespējams, ir jābūt masīvam vai 16 bitu int, un funkcijaiI2C_Read_Register
ir jāatgriež 16 bitu int. Ja jūs ievietojat pārtraukuma punktu*buf++ = data ;
, vai redzat to pašu, ko redz jūsu analizators? - person yhyrcanus   schedule 07.08.2019