CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

PIC18F4431 I2C issue

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
valery_che



Joined: 04 Jan 2016
Posts: 5

View user's profile Send private message

PIC18F4431 I2C issue
PostPosted: Tue Jan 05, 2016 12:12 pm     Reply with quote

Hello!

I need to make a communication between PIC18F4550 (Master) and PIC18F4431 (Slave) via I2C. 18F4550 working good with another slaves (another PIC18F4550 for tests). I2C bus scanner don`t see 18F4431. Also, 18F4550 with the same code as slave working okey. It seems like I2C module fully doesn`t work in my 18F4431. What`s wrong?

Here is code for 18f4431:

Code:

#include <c:\Program files (x86)\PICC\Devices\18F4431.h>

#DEVICE HIGH_INTS=TRUE

#fuses HS, NOWDT, NOPROTECT, NOLVP
#use delay(clock=16 000 000)

#use i2c(Slave, sda=PIN_D2, scl=PIN_D3, address=0xA0, FORCE_HW)

int data = 0, state = 0;

#INT_SSP
void ssp_interrupt()
{
   state = i2c_isr_state();
   
   if(state < 0x80)     // Master is sending data
   {
      data = i2c_read(); 
   }

   if(state >= 0x80)   // Master is requesting data from slave
   {
      i2c_write(0);
   }
 
   output_bit(PIN_B4, TRUE); // Never turns on LED
}

void main()

   enable_interrupts(INT_SSP);
   enable_interrupts(GLOBAL);
   
   output_bit(PIN_B4, FALSE); //Led
   delay_ms(100);
   output_bit(PIN_B4, TRUE);
   delay_ms(50);
   output_bit(PIN_B4, FALSE);
   
   while (TRUE) { /*
     output_bit(PIN_B4, TRUE);
     delay_ms(100);
   
     output_bit(PIN_B4, FALSE);
     delay_ms(100); */
   }
}
temtronic



Joined: 01 Jul 2010
Posts: 9295
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Jan 05, 2016 1:42 pm     Reply with quote

hmmm go back to step one...

create a 1Hz LED program for the 4431. Does it function properly,ie: flash LED at 1 Hz rate ?

step two...
confirm your 4431 is correctly wired for I2C and has appropriate pullups on the I2C busses.

step 3...
report back your observations.

my guess is the 4431 isn't running....

Jay
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Tue Jan 05, 2016 3:40 pm     Reply with quote

I got bad generated code (00 for register addresses), until I used i2c1
in the library declaration. Also you do need to tell the PIC to use
the PortD pins for i2c. That is done with a fuse setting. Try it with
the changes shown in bold below.
Quote:
#include <18F4431.h>
#fuses HS, NOWDT, NOPROTECT, NOLVP, SSP_RD
#use delay(clock=16M)
#use i2c(Slave, i2c1, address=0xA0)
valery_che



Joined: 04 Jan 2016
Posts: 5

View user's profile Send private message

PostPosted: Tue Jan 05, 2016 4:50 pm     Reply with quote

temtronic wrote:
hmmm go back to step one...

create a 1Hz LED program for the 4431. Does it function properly,ie: flash LED at 1 Hz rate ?

step two...
confirm your 4431 is correctly wired for I2C and has appropriate pullups on the I2C busses.

step 3...
report back your observations.

my guess is the 4431 isn't running....

Jay


Yes, LED blinking directly 1 time per second. So, 18F4431 is on. And wireds for I2C connected right.
valery_che



Joined: 04 Jan 2016
Posts: 5

View user's profile Send private message

PostPosted: Tue Jan 05, 2016 4:57 pm     Reply with quote

PCM programmer wrote:
I got bad generated code (00 for register addresses), until I used i2c1
in the library declaration. Also you do need to tell the PIC to use
the PortD pins for i2c. That is done with a fuse setting. Try it with
the changes shown in bold below.
Quote:
#include <18F4431.h>
#fuses HS, NOWDT, NOPROTECT, NOLVP, SSP_RD
#use delay(clock=16M)
#use i2c(Slave, i2c1, address=0xA0)


After enabled fuse SSP_RD all I2C functions on 18F4431 working! Thanks a lot!
Ttelmah



Joined: 11 Mar 2010
Posts: 19620

View user's profile Send private message

PostPosted: Wed Jan 06, 2016 2:14 am     Reply with quote

Hurrah!... Smile

As a separate 'long term warning', I had problems with the I2C slave on the 4431. This is (partially) related to the errata sheet DS80132F.

I had to implement the timeout mentioned here, or just occasionally found that the normal repeated start was incorrectly handled, and the unit would not recover. Now it should not happen (the conditions they say trigger it, are both ones that my master was not generating - never sent two 'read starts' back to back, or a second start during a transaction). My code was using normal I2C protocols with the only repeated start being when I reversed bus direction for a read. However just once in perhaps 100000 transactions, the I2C would then get hung (intermittent after several days...). I ended up just starting a timer, when the address match occurred, disabled this when the transaction completed, and if this reached it's end count, reset the I2C (SSPEN off, then on). I set the timer to give me about 0.1 seconds, and had the master setup to retry after just a little longer, if it didn't get the get the correct ACK/NACK on the data bytes from the read. This has been 100% since. The 4431, is the only chip that has ever shown this for me.

So 'beware'. I had to use the 4431, since I wanted it's PWM functionality, and at the time it was the only chip with this, but I have a 'red flag' now in my design notes, to 'beware' when using the I2C on this....
valery_che



Joined: 04 Jan 2016
Posts: 5

View user's profile Send private message

PostPosted: Wed Jan 06, 2016 8:57 am     Reply with quote

Ttelmah wrote:
Hurrah!... Smile

As a separate 'long term warning', I had problems with the I2C slave on the 4431. This is (partially) related to the errata sheet DS80132F.

I had to implement the timeout mentioned here, or just occasionally found that the normal repeated start was incorrectly handled, and the unit would not recover. Now it should not happen (the conditions they say trigger it, are both ones that my master was not generating - never sent two 'read starts' back to back, or a second start during a transaction). My code was using normal I2C protocols with the only repeated start being when I reversed bus direction for a read. However just once in perhaps 100000 transactions, the I2C would then get hung (intermittent after several days...). I ended up just starting a timer, when the address match occurred, disabled this when the transaction completed, and if this reached it's end count, reset the I2C (SSPEN off, then on). I set the timer to give me about 0.1 seconds, and had the master setup to retry after just a little longer, if it didn't get the get the correct ACK/NACK on the data bytes from the read. This has been 100% since. The 4431, is the only chip that has ever shown this for me.

So 'beware'. I had to use the 4431, since I wanted it's PWM functionality, and at the time it was the only chip with this, but I have a 'red flag' now in my design notes, to 'beware' when using the I2C on this....


Thank you for a great comment! I chose 18F4431 exactly for advanced PWM module. But after your story it seems like that isn't "friendly" chip for I2C communication. I need to control up to 6 servos and have enable to exchange data via I2C. Can you give me advice about 18F chip for that task?
Ttelmah



Joined: 11 Mar 2010
Posts: 19620

View user's profile Send private message

PostPosted: Wed Jan 06, 2016 12:13 pm     Reply with quote

Unfortunately, the 2431/4431, is the only PIC18 with the power control PWM module that I know of. It's annoying, also, that the Microchip search doesn't allow this to be searched for (no column for this in their search). It's the slave I2C, that has problems (it also has an initialisation problem that hit me, I posted here about this at the time). If I was doing this now, I'd use a PIC33, the performance for the maths is just so much better, Something like the DSPIC33FJ16MC102 for a small chip (like the 2431). The relocatable peripherals make these so much more friendly....
Consider if you could do the communications to the slaves using something like RS485, instead of I2C?. Avoids the problems.
valery_che



Joined: 04 Jan 2016
Posts: 5

View user's profile Send private message

PostPosted: Wed Jan 06, 2016 12:44 pm     Reply with quote

Ttelmah wrote:
Unfortunately, the 2431/4431, is the only PIC18 with the power control PWM module that I know of. It's annoying, also, that the Microchip search doesn't allow this to be searched for (no column for this in their search). It's the slave I2C, that has problems (it also has an initialisation problem that hit me, I posted here about this at the time). If I was doing this now, I'd use a PIC33, the performance for the maths is just so much better, Something like the DSPIC33FJ16MC102 for a small chip (like the 2431). The relocatable peripherals make these so much more friendly....
Consider if you could do the communications to the slaves using something like RS485, instead of I2C?. Avoids the problems.


Hm. dsPIC really good option. But now I may be start using RS232 or RS485. Thank you so much!
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group