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

I2C changing slave address

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



Joined: 11 Dec 2010
Posts: 11
Location: Germany

View user's profile Send private message

I2C changing slave address
PostPosted: Sat Dec 11, 2010 4:04 am     Reply with quote

Hello!
I have a Pic to Pic bus system with one master (18F4550) and more slaves (16F1826) connected via I2C.
Is it possible to change the address of the slave by software?
My idea is to have all the slaves first programmed with the same address (same software). Then connect one after another (not more then one at a time) to the master and after first connection via the first address, I wish to change the slave address via the master sending the new address to the slave.
The slave will change the address then and after a reset it will have the new address (until the address is changed again in the same way).
Also possible option: depending on the input of two or three pins of the slave pic the software will set the address when it starts up.

What do you mean?

Thanks.
Johann Question
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Sat Dec 11, 2010 4:45 am     Reply with quote

The last line, is the easiest.
This is how it is done on a lot of standard chips.

It is possible, using GCA, but you are always going to have the complexity of actually knowing for sure which chip is which. Since they all have the same code, making them choose/respond to different addresses will always be difficult. Much easier to just have some pins, selecting which address each chip uses. Also means that when you plug a new chip into a given location, you know that chip will respond to the same address as the last one...

Best Wishes
Johann17943



Joined: 11 Dec 2010
Posts: 11
Location: Germany

View user's profile Send private message

PostPosted: Sat Dec 11, 2010 5:37 am     Reply with quote

Hello Ttelmah,

thanks for so quick answer!
Perhaps I should explain a little more detailed my project, for understanding.
The master and slave is not on the same board. I have one master device (board) connected via wire to more slave devices. The slave board will have always the same board with the same pic (and same software). The slave will activate 4 dc motors, the start and time of running a motor will come via I2C from the master. Because the slaves are connected in parallel to the I2C it is possible to connect up to 3 slaves (12 motors) to the master. The master code allows to control these 12 motors (on 3 slave devices). There are not always connected all 3 slaves.
If the slave address would be able to be changed by software, I would start to connect one slave, then search by the 3 possible addresses which slave is connected and have then the possibility to change the address.
If the slave address would be controlled by slave pic pins, I would have two switches/jumpers on the slave board to set the address.
As you can see the first option would be much better, I do not need jumpers or to open the device.
Important is for me to know how to set the address in the #use i2c(...):
1. address pointed to an address in the eeprom?
2. use the #use i2c(..) in main() where it can be set depending on an eeprom-value or the input of some pins

If you know how, please explain like for a dummy, I'm not so specialist in these (I have some experience in I2C communication with an RTC) and basic CCS-compiler knowledge.

Thanks.
Johann
temtronic



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

View user's profile Send private message

PostPosted: Sat Dec 11, 2010 7:17 am     Reply with quote

I did 'remote address programming several years ago, so your idea is valid. Basically when a new 'device' is seen by the master, the master would assign the 'slave' an address,adding it to the database of slaves online.
You may have a problem with the I2C bus (timing, collisions, data corruption) if more than one slave is added to the bus at the same time. The master could see both slaves and their data mixed together (a ghosting condition). Providing you add one slave at a time and is configured to a unique address I do not see any technical issues. If you have an extra LED on the slaves, use it to confirm that an address has been issued and it is 'online'.
In my system, 4 LEDs were used to display the slave address and then blink to confirm online status (that was over 25 years ago..) using a handful of 4000 series CMOS chips. Today a single PIC will do it and much more !
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Sat Dec 11, 2010 11:03 am     Reply with quote

I have not played with I2C much, but you might want to check out how DHCP works in the ethernet world. It accomplishes what you are asking - basically a slave would announce that it was there and wanted an address, the master would "offer" a new address and then the "slave" accepts/acknowledges the address (that allows the case where more than one "dhcp server" can hand out addresses. The master now knows it has handed out a new address from it's available "pool" of addresses. The part that is missing is that usually there is a unique (or supposed to be anyway) MAC address that does not change associated with each interface. You could accomplish the same thing by giving each board a serial number that it uses when it requests an actual address. Just a thought.

A couple of links that may help you (or give you ideas)
http://en.wikipedia.org/wiki/Dynamic_Host_Configuration_Protocol
http://kb.iu.edu/data/adov.html

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
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