Email: Password: Remember Me | Create Account (Free)

Back to Subject List

Old thread has been locked -- no new posts accepted in this thread
???
02/04/09 21:02
Read: times


 
#162072 - Updated, but errors on my part
Responding to: ???'s previous message
I know I'm doing something silly wrong, I can't put my figure on it. I like your suggestion, I thought this would follow that model, clearly it isn't. Still working on it, but the error (among multiple others) is at the end of this post due to a pointer error. Any thoughts where I'm going wrong?



I2C.C file

unsigned char i2c_transmit(unsigned char address, *transmit_bytes, uchar num_bytes_send);

{

  //extern unsigned char byte1, byte2;
  // if already busy then return current status
  if (i2cstatus & I2C_BUSY) return i2cstatus;

  // now we are busy performing a transfer
  i2cstatus = I2C_BUSYTX;

  // store slave address + W for use in ISR
  slaveaddress = address << 1;

  // transmit start condition
  STA = 1;

  // transmission started
  return I2C_OK;
}

=========================================================================
Defined in i2c.h file

extern unsigned char i2c_transmit(unsigned char address, *transmit_bytes[], uchar MAX_NUMBYTE_TX[]);
=========================================================================

Defined in IO.c file

uchar MAX_NUMBYTE_TX[] = {7};
=========================================================================

Defined in I/O.c

unsigned char transmit_bytes[] = {0,0,0,0,0,0,0};//Holds I2C data bytes
						 //only
						 //Not address
extern unsigned char MAX_NUMBYTE_TX[];

=========================================================================

called from main.c

MAX_NUMBYTE_TX[0] = 0; //Transmit 1 bytes of DATA ONLY on I2C  
i2c_init(0x20, 0); //Set to master with address of 0x20, no general call
i2c_transmit(0x3B, 0x03);  // enable mux channels 0-1
while (i2c_getstatus() & I2C_BUSY);	// wait until complete

MAX_NUMBYTE_TX[0] = 1;
i2c_init(0x20, 0); //Set to master with address of 0x20, no general call
i2c_transmit(0x3B, 0x03, 0x04);  // enable mux channels 0-1
while (i2c_getstatus() & I2C_BUSY);	// wait until complete

MAX_NUMBYTE_TX[0] = 2;
i2c_init(0x20, 0); //Set to master with address of 0x20, no general call
i2c_transmit(0x3B, 0xfe, 0x04, 0x05);  // enable mux channels 0-1
while (i2c_getstatus() & I2C_BUSY);	// wait until complete



 


Getting error: I2C.H(25): error C141: syntax error near '*' for > extern unsigned char i2c_transmit(unsigned char address, *transmit_bytes[], uchar MAX_NUMBYTE_TX[]);


List of 14 messages in thread
TopicAuthorDate
dynamic parameters in an I2C definition possible?            01/01/70 00:00      
   how about            01/01/70 00:00      
      trans_byte buffer?            01/01/70 00:00      
         something like:            01/01/70 00:00      
            Updated, but errors on my part            01/01/70 00:00      
               This            01/01/70 00:00      
                  I must be stuck on stupid            01/01/70 00:00      
                     I Think it is this            01/01/70 00:00      
                        Array of pointers to characters            01/01/70 00:00      
               Try this code            01/01/70 00:00      
                  Works great!...One question though            01/01/70 00:00      
                     The warning is real            01/01/70 00:00      
                     Not exactly as I coded            01/01/70 00:00      
                        Update......Problem solved            01/01/70 00:00      

Back to Subject List