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

PIC18F2550 eeprom 24LC32A interfacing problem
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
SubhamayS



Joined: 07 Mar 2012
Posts: 34
Location: jalpaiguri, India

View user's profile Send private message

PIC18F2550 eeprom 24LC32A interfacing problem
PostPosted: Fri Jul 07, 2017 2:49 am     Reply with quote

I am trying to interface Microchip 24LC32A EEPROM with PIC18F2550. I am using the driver provided by CCS (2432.c).

Compiler version 5.015

I have used PIN_B2, PIN_B3, PIN_B4 for checking the execution of the code. But only PIN_B2 goes high as I check the code in hardware.
The LCD, RS232 part of the codes are working fine. I have connected two 10k pullup resistors to SDA & SCL lines & WP connected to GND. As shown here https://www.ccsinfo.com/forum/viewtopic.php?t=30393

Code:
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, ERRORS)

#define EEPROM_SDA  PIN_B0
#define EEPROM_SCL  PIN_B1

#include <2432.c>

//=====================================
void main()
{
//================================
   lcd_init();                   // Turn LCD ON, along with other initialization commands
   delay_ms(50);
   lcd_gotoxy(1,1);              // point LCD cursor to col1 row1
   delay_ms(10);
   lcd_putc("\f");
   printf(lcd_putc,"EEPROM DEMO\n");  // print on LCD
   delay_ms(1000);
//================================
   init_ext_eeprom();            // to initialize EEPROM
   output_high(PIN_B2);
   write_ext_eeprom(0, 55);
   delay_ms(10);
   output_high(PIN_B3);
   write_ext_eeprom(2, 85);
   delay_ms(10);
   output_high(PIN_B4);
   printf(lcd_putc,"data@0 %d", read_ext_eeprom(0));
   delay_ms(50);
   lcd_gotoxy(9,1);
   printf(lcd_putc,"data@2 %d", read_ext_eeprom(2));
   delay_ms(50);
   while(1);
}


The 2432.c driver I am using is given below:

Code:
#ifndef EEPROM_SDA

#define EEPROM_SDA  PIN_C4
#define EEPROM_SCL  PIN_C3

#endif


#define hi(x)  (*((int8 *)&x+1))

#use i2c(master, sda=EEPROM_SDA, scl=EEPROM_SCL)

#define EEPROM_ADDRESS long int
#define EEPROM_SIZE    4096

void init_ext_eeprom() {
   output_float(EEPROM_SCL);
   output_float(EEPROM_SDA);
}

BOOLEAN ext_eeprom_ready() {
   int1 ack;
   i2c_start();            // If the write command is acknowledged,
   ack = i2c_write(0xa0);  // then the device is ready.
   i2c_stop();
   return !ack;
}

void write_ext_eeprom(long int address, BYTE data) {
   while(!ext_eeprom_ready());
   i2c_start();
   i2c_write(0xa0);
   i2c_write(hi(address));
   i2c_write(address);
   i2c_write(data);
   i2c_stop();
}


BYTE read_ext_eeprom(long int address) {
   BYTE data;

   while(!ext_eeprom_ready());
   i2c_start();
   i2c_write(0xa0);
   i2c_write(hi(address));
   i2c_write(address);
   i2c_start();
   i2c_write(0xa1);
   data=i2c_read(0);
   i2c_stop();
   return(data);
}


Please Help. I am unable to identify the fault in the code. Rolling Eyes
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 3:13 am     Reply with quote

You say you never get led B3 to light up. So it's probably locking up
in this routine:
Code:
write_ext_eeprom(0, 55);


So, you can move the lines for leds B3 and B4 to troubleshoot that routine
in the 2432.c driver. Example:
Code:
void write_ext_eeprom(long int address, BYTE data) {
output_high(PIN_B3);
   while(!ext_eeprom_ready());
output_high(PIN_B4);
   i2c_start();
   i2c_write(0xa0);
   i2c_write(hi(address));
   i2c_write(address);
   i2c_write(data);
   i2c_stop();
}

My guess is it will light up leds B2 and B3, but led B4 will not light.
At that point, you should start closely looking at your connections
and resistor values.
SubhamayS



Joined: 07 Mar 2012
Posts: 34
Location: jalpaiguri, India

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 4:00 am     Reply with quote

PCM programmer wrote:
My guess is it will light up leds B2 and B3, but led B4 will not light.
At that point, you should start closely looking at your connections
and resistor values.


You are right. I tried to test as per your advice. I have added the lines to 2432.c.
LED at B3 lights up but LED at PIN_B4 does not glow.

I have checked the connections everything is ok. due to 10k pull up resistor the
potential at (EEPROM pins) SDA & SCL is 4.72 Volts. I have connected SDA to PIN_B0 to SDA & PIN_B1 to SCL. is it an issue with the 10k resistor ?
temtronic



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

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 5:13 am     Reply with quote

I suggest replacing the 10K pullups with 4K7. I'm currently bench testing a product that has both the 24LC32 and a DS3231 RTC and the pullups are 4K7. Just measured with DVM, yeesh SMT Rs are small !
I know the driver does work though I did add extensions for both page write (32 bytes) as well as fast erase (128 page mode erases).

I also suggest you download and run the I2C Scanner program from the code library (3-4 posts down...). It makes I2C troubleshooting EASY ! It DOES finds any device on the I2C bus. Just be sure to code the correct I/O pins ! In my case I'm using an 18F46K22 which has 2 I2C busses and needed to code for BOTH busses......

Also as already stated, be sure to check the connections again.

Jay
SubhamayS



Joined: 07 Mar 2012
Posts: 34
Location: jalpaiguri, India

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 6:06 am     Reply with quote

I have used the 4.7 k resistors this time and tried the I2C Scanner code. it returned:

Code:

Start:


Nothing Found


This is the code I have used (from code library):

Code:
#use i2c(Master, sda=PIN_B0, scl=PIN_B1)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7, ERRORS)

// This function writes the slave address to the i2c bus.
// If a slave chip is at that address, it should respond to
// this with an "ACK".   This function returns TRUE if an
// ACK was found.  Otherwise it returns FALSE.
int8 get_ack_status(int8 address)
{
int8 status;

i2c_start();
status = i2c_write(address);  // Status = 0 if got an ACK
i2c_stop();

if(status == 0)
   return(TRUE);
else
   return(FALSE);
}


//=================================
void main()
{
unsigned int8 i;
unsigned int8 status;
unsigned int8 count = 0;

printf("\n\rStart:\n\r");

delay_ms(1000);

// Try all slave addresses from 0x10 to 0xEF.
// See if we get a response from any slaves
// that may be on the i2c bus.
for(i=0x10; i < 0xF0; i+=2)
   {
    status = get_ack_status(i);
    if(status == TRUE)
      { 
       printf("ACK addr: %X\n\r", i);
       count++;
       delay_ms(2000);
      }
   }

if(count == 0)
   printf("\n\rNothing Found");
else
   printf("\n\rNumber of i2c chips found: %u", count);

while(1);
}


Pin: 1,2,3,4 of EEPROM connected to GND,
PIN- 8 to VCC (+5V),
PIN- 7 (WP) TO GND,
PIN- 5 (SDA) to PIN_B0
PIN- 6 (SDA) to PIN_B1

still not working.. Sad
temtronic



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

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 10:00 am     Reply with quote

OK, since the Scanner program didn't find it, I suspect a wiring error. I KNOW the Scanner works 100%!
While you mention WP, I just downloaded the uChp PDF and there is no Write Protect pin, just 3 chip select/address lines.
If those are all tied to ground then it's addess should be 0xA0/0xA1.

It is important to know which EEPROM it is, the Atmel ones ARE different, so you can't use the Atmel datasheet when using the uChp device.

If this is a homemade PCB check for shorts or grounds.

If an 'experimenters board', again, confirm all the wiring.

Jay
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 12:50 pm     Reply with quote

SubhamayS wrote:
Pin: 1,2,3,4 of EEPROM connected to GND,
PIN- 8 to VCC (+5V),
PIN- 7 (WP) TO GND,
PIN- 5 (SDA) to PIN_B0
PIN- 6 (SDA) to PIN_B1

still not working..

(of course you mean SCL to PIN_B1)

You may have:
1. A defective 24LC32A chip. Try another one. Where did you get it ?
If from eBay, it could be a counterfeit, non-working chip.
2. A defective PIC, or pins B0 and B1 are bad on that PIC.
3. Defective connections or resistors.
4. Defective compiler.
5. Poor power supply regulation.


temtronic wrote:

I just downloaded the uChp PDF and there is no Write Protect pin

Go to this page:
http://www.microchip.com/wwwproducts/en/24LC32A
Click on the link for Documentation. Go down there and get the link
for the 24LC32A data sheet:
http://ww1.microchip.com/downloads/en/DeviceDoc/21713M.pdf
The first chip diagram on the lower left has WP on pin 7.
temtronic



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

View user's profile Send private message

PostPosted: Fri Jul 07, 2017 2:34 pm     Reply with quote

hmm seems the A is important.....I downloaded the nonA version,sigh...

I have to wonder though HOW counterfeit EEPROMs could be profitable..do 'they' just make 8 legged 'devices' and put numbers on them? IE NOTHING inside ??
SubhamayS



Joined: 07 Mar 2012
Posts: 34
Location: jalpaiguri, India

View user's profile Send private message

PostPosted: Fri Mar 23, 2018 9:37 am     Reply with quote

PCM programmer wrote:
You may have:
1. A defective 24LC32A chip. Try another one. Where did you get it ?
If from eBay, it could be a counterfeit, non-working chip.
2. A defective PIC, or pins B0 and B1 are bad on that PIC.
3. Defective connections or resistors.
4. Defective compiler.
5. Poor power supply regulation.


Its original. I bought it from microchipdirect.
and the PIC is working fine (PIN B0 & B1).

Changed the EEPROM IC. The problem still persists.

I am using ccs bootloader in this program.
Oscillator connected is 20 MHz with PLL5. can this be the issue ? Rolling Eyes
Configs are shown below.

Code:
#include <18F2550.h>
#fuses HSPLL,NOWDT,NOPROTECT,NOLVP,NODEBUG,USBDIV,PLL5,CPUDIV1,VREGEN
#use delay(clock=48000000)
#include <usb_bootloader.h>

I have changed the default #use i2c in 2432.c file to the following ?
Code:
#use i2c(master, sda=EEPROM_SDA, scl=EEPROM_SCL, slow=100000, FORCE_HW)


as per the document : http://ww1.microchip.com/downloads/en/AppNotes/00989A.pdf

it says that the SDA and SCL pins are open-drain terminals,
and therefore require pull-up resistors to VCC (typically
10 kΩ for 100 kHz, and 2 kΩ for 400 kHz and 1 MHz) I am using 10 k pull-up resistors so I have mentioned slow=100000 in #use i2c.

BUT STILL NOTHING SEEM TO WORK ! Crying or Very sad

PLEASE HELP !
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Fri Mar 23, 2018 10:05 am     Reply with quote

Post a link to a schematic and also a photo of your board.


To show images on this forum, you have to upload them to a free image
hosting website (ex. Tinypic.com) and then post either a link or a hotlink
to your post in this thread. Then we can see your images. If you post
a hotlink, don't make the images too big. Maybe 1024x768 max.
If you don't like Tinypic.com, there are other websites.
Do a web search for: free forum image hosting
SubhamayS



Joined: 07 Mar 2012
Posts: 34
Location: jalpaiguri, India

View user's profile Send private message

PostPosted: Sun Mar 25, 2018 12:05 am     Reply with quote

PCM programmer wrote:
Post a link to a schematic and also a photo of your board.


Please find below, the image of schematic.
http://i66.tinypic.com/2801g0z.jpg

Is it a problem with of the MSSP clock ? because I am using CCS USB bootloader in my board, 20 Mhz crystal, generating 48 MHz clock with PLL5.
Ttelmah



Joined: 11 Mar 2010
Posts: 19587

View user's profile Send private message

PostPosted: Sun Mar 25, 2018 9:23 am     Reply with quote

Some comments:
Don't confuse Vusb on the PIC with the USB 5v line. Vusb, is an internal voltage developed by the on chip regulator, and _must_ have a nice low impedance cap mounted close to the chip and nothing else.

If you are using a device powered by an external source (you are), with a USB connection, USB _requires_ (yes, it's part of the spec), the connection sense signal.

Your MCLR connection doesn't work....
As shown, neither the reset button or the capacitive boot circuit can ever take MCLR low.

You only show 1*0.1uF capacitor. There should be at least another on the EEPROM.
The size of the pull-ups is dependant on the I2C clock speed, and the capacitance on the bus. How long are the I2C connections?. What sort of wire?.

Add the fuse NOPBADEN. This is probably the problem. You don't have any ADC setup line, and with the PBADEN (which I think defaults 'on'), the whole of PortB is setup for analog.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sun Mar 25, 2018 9:38 pm     Reply with quote

I don't think it's the lack of NOPBADEN. The startup code in main() sets
the PCFGx bits to all 1's in ADCON1, which makes PortB all digital i/o.
Quote:

.................... void main(void)
0004: CLRF TBLPTRU
0006: BCF RCON.IPEN
0008: MOVLW 60
000A: MOVWF OSCCON
000C: MOVF OSCCON,W
000E: CLRF rs232_errors
0010: BCF BAUDCON.BRG16
0012: MOVLW 19
0014: MOVWF SPBRG
0016: MOVLW A6
0018: MOVWF TXSTA
001A: MOVLW 90
001C: MOVWF RCSTA
001E: MOVF ADCON1,W
0020: ANDLW C0
0022: IORLW 0F
0024: MOVWF ADCON1
0026: MOVLW 07
0028: MOVWF CMCON


I think it's got to be something like:
1. The SDA and SCL lines are swapped.
2. The 10K resistors are really 1 Meg.
3. Some connection that is shown is actually not there or is a cold-solder joint.
Or something like that.
Ttelmah



Joined: 11 Mar 2010
Posts: 19587

View user's profile Send private message

PostPosted: Mon Mar 26, 2018 12:00 am     Reply with quote

Did you check with 5.015?.
I remember some versions about that time did not default to disabling the ADC. It would explain the behaviour.
I'll have to go and see if I have .015 to test.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Mar 26, 2018 12:27 am     Reply with quote

vs. 5.015 does the same thing. It sets PortB to all digital.
Code:

CCS PCH C Compiler, Version 5.015, xxxxx      25-Mar-18 23:25

0004:  CLRF   TBLPTRU
0006:  BCF    RCON.IPEN
0008:  MOVLW  60
000A:  MOVWF  OSCCON
000C:  MOVF   OSCCON,W
000E:  CLRF   rs232_errors
0010:  BCF    BAUDCON.BRG16
0012:  MOVLW  19
0014:  MOVWF  SPBRG
0016:  MOVLW  A6
0018:  MOVWF  TXSTA
001A:  MOVLW  90
001C:  MOVWF  RCSTA

001E:  MOVF   ADCON1,W
0020:  ANDLW  C0
0022:  IORLW  0F
0024:  MOVWF  ADCON1  // PCFGx bits = 1111

0026:  MOVLW  07
0028:  MOVWF  CMCON
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
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