[SOLVED] I2C-Hardware problem

Status
Not open for further replies.

sundar11

Member level 1
Joined
Apr 16, 2014
Messages
41
Helped
2
Reputation
4
Reaction score
2
Trophy points
8
Visit site
Activity points
272
Hi everyone
I am trying to communicate between two lpc2148 using i2c. I have got output in proteus Simulation. but in hardware i am not getting any output. i have used pullup resistor value of 10K each and supply voltage 3.3v i am using nxp development board, i am using polling method for both master and slave. any suggestions would be helpful.
 

Ensure that one chip is master & other is slave. What is the output of I2C clock & data when you are probing? are you getting a clock output when probing? is the master is toggling data bits?

- - - Updated - - -

If output is High= Nobody is driving the bus, check on your master configuration,
If output is Low= Somebody is driving the bus / both are driving the bus
 

HI
thanks for responding

the master is toggling the data , and the clock is low
 

Hi everyone

I figured out the reason, there must be some delay between each data transfer, but again i am unable to identify the correct delay required for the data transfer between the mcu's. Any suggestions would be helpful


Regards
Sundar !!
 

Hi,for debug the iic,i use to catch the IIC wave by logic analyze,you can view the IIC speed ,it must less than 400khz....
Regards
Sundar!!
 

Hi
i have a Saleae logic analyzer with me, can you explain the procedure for analyzing a i2c protocol using the logic analyzer. By checking the user guide i understand some basic things, but there is no response from the logic analyzer.


Regards
Sundar
 

What delay are you talking about?between the stop & immediate start, the minimum bus free time is 4.7us for standard mode, 1.3us for fast mode.

Clock is low means, it is not toggling??
 

Hi Sankar


The master has to wait after sending the start condition, then only the slave responds with acknowldgement, or else the slave returns NACK. so after sending start i am using 60ms delay, so that the slave will respond to it. All this happens in proteus simulation, but no response in hardware. The clock toggles no problem with that.



Regards
sundar
 

After start condition, you need to provide the slave address followed by Rd/Wr bit, & on the 9th clock you will receive the acknowledgement. If you are not getting the acknowledgement, check the I2C address of the slave.
 

In what speed you are running the clock?...try to reduce the clock and check...verify the data which is sent by the master (Address) is correct by probing with respect to clock.
 

Hi
Thanks for your reply, my clock speed is 100 khz. i think the problem is with the slave address. it did'nt acknowledges properly. is there is specific way to determine the slave address. i am using lpc2148 as slave. i fixed the address as 0x80, and tryied to communicate. i used pullup resistor value as 4.7K. supply voltage 3.3 v



Regards
Sundar
 

Hi
I have used slave address as 0x80.. i loaded it as the first byte in master transcation and in the slave address register i loaded it.. but some times the slave replies with ack, and some times it returns NACK.. if i increase the delay(60ms) the response changes vice versa. i struggling to fix this issue... any ideas would be helpful. i have attached the logic analyser snap shots.
 

Attachments

  • screenshot.png
    72.9 KB · Views: 120
  • screenshot11.png
    82.1 KB · Views: 121

Hi,

Is the lpc2148 the only slave on the bus? No other slave or master causes the problems?

I don't know the lpc chip, but is itvpossible that the chip is busy sometimes and can not react to the bus.

Klaus
 

Hi Sunder, I am not seeing the slave address 0x80 on the waveform you are provided. the SDA's falling edge is coinciding with SCL's high which means a start condition, Followed by an address 0x0. Why the SCL & SDA are initially LOW ? In the second figure, START condition is not achieved.
 

Hi sankar
sorry for the late reply. while checking this issue i found the clock is always low except during the start condition. and again after the start condition the sda is always high and scl is always low. what might be the reason for this issue. but the code works with proteus simulation. any suggestions would be helpful.



Regards

Sundar
 

Hi shruv

Thanks for your help.. i gone through the code, its really useful.. in slave what states are you checking, i am checking 0x60 and 0x80. any suggestions..
 

Any other device on I2C bus?..is it possible to isolate (removing power also ok) the each chip so that we can check which device is driving the bus LOW (Clock).
 

Status
Not open for further replies.

Similar threads

Cookies are required to use this site. You must accept them to continue using the site. Learn more…