|
|
View previous topic :: View next topic |
Author |
Message |
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
SOLVED: i2c_speed - unable to resolve identifier i2c_speed |
Posted: Mon Mar 21, 2016 5:32 am |
|
|
Hi,
I found i2c_speed in the ccs c manual, but the compiler gives "unable to resolve identifier i2c_speed".
Note the other functions i2c_start, i2c_write, i2c_read, and i2c_stop work fine.
I use a PIC18F67K90 @ 20MHz.
I have used:
#use i2c
Code: |
i2c_speed(400000); // unable to resolve identifier i2c_speed
i2c_start();
i2c_write(MCP7940_ADDRESS);
i2c_write(address);
|
Why is the function not known?
Regards,
Jack.
Last edited by JackB on Thu Mar 24, 2016 5:45 am; edited 1 time in total |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9253 Location: Greensville,Ontario
|
|
Posted: Mon Mar 21, 2016 5:57 am |
|
|
might be a compiler version bug ?
which compiler do you have ? |
|
|
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
|
Posted: Mon Mar 21, 2016 6:07 am |
|
|
Thanks for the quick response!
I also have: Option invalid - Bad Option: #use i2c
In the lst file I found:
CCS PCH C Compiler, Version 5.055, 29447
I'm using it with MPLAB X on a Linux Mint laptop. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9253 Location: Greensville,Ontario
|
|
Posted: Mon Mar 21, 2016 6:13 am |
|
|
did a real quick check...
i2c_speed(xxx);
ONLY works for the HARDWARE I2C module according to the manual (F11)
it should be available for all PICs with HW I2C.
reply with full #use i2c(....)
that error says 'something' in (......) is wrong, not allowed, typo, etc.)
Jay |
|
|
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
|
Posted: Mon Mar 21, 2016 7:16 am |
|
|
Thanks,
now I use:
#use i2c(MASTER, FAST, SCL=PIN_C3, SDA=PIN_C4)
It still doesn't know this function
i2c_speed(400000);
But I guess, I addressed that with "FAST"? |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Mon Mar 21, 2016 7:39 am |
|
|
JackB wrote: | now I use:
#use i2c(MASTER, FAST, SCL=PIN_C3, SDA=PIN_C4)
It still doesn't know this function |
Read the CCS manual in the #use i2c section. It says: Quote: |
#use i2c( )
Software functions are generated unless FORCE_HW is specified. |
Then read the manual in the i2c_speed() section. It says:
Quote: | i2c_speed( )
This only works if the hardware I2C module is being used. |
You are using software i2c. That's why you get the error. |
|
|
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
|
Posted: Mon Mar 21, 2016 7:55 am |
|
|
I use FORCE_HW, it still gives a warning for the i2c_speed function, but it compiles.
However, the software starts to hang after the first i2c_write(MCP4726_ADDRESS); function. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19562
|
|
Posted: Mon Mar 21, 2016 8:19 am |
|
|
Several comments:
1) It is much easier and safer, to just specify the I2C port to use:
#use i2c(MASTER, FAST, I2C1)
is equivalent to:
#use i2c(MASTER, FAST, SCL=PIN_C3, SDA=PIN_C4, FORCE_HW)
and means you can't get the pin numbers wrong. On later chips with relocatable peripherals, you have to use this syntax, so it is worth always using it when you want the hardware.
2) Why not just specify the speed in the use statement?:
#use i2c(MASTER, FAST=400000, I2C1)
3) The most likely reason for it hanging, is that some feature of the bus prevents 400K from working:
A device too slow for this.
Pull up resistors too large.
Too much capacitance on the bus.
The second and third link to one another, and to what voltage you are using to drive the bus.
Do you have any other devices on the I2C bus?.
What pull-up values are you using?.
How long is the connection, what sort of wire?. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Mon Mar 21, 2016 8:41 am |
|
|
JackB wrote: | I use FORCE_HW, it still gives a warning for the i2c_speed function |
You said in another thread that this is your version:
Quote: | CCS PCH C Compiler, Version 5.055. |
You didn't provide a test program so I made one, as shown below.
I compiled it with vs. 5.055 and there are no errors at all:
Code: | Executing: "C:\Program files\Picc\CCSC.exe" +FH "PCH_Test.c" +DF +LY -T -A +M -Z +Y=9 +EA #__18F67K90=TRUE
Memory usage: ROM=0% RAM=0% - 0%
0 Errors, 0 Warnings.
Build Successful.
Loaded C:\Program Files\PICC\Projects\PCH_Test\PCH_Test.cof.
BUILD SUCCEEDED: Mon Mar 21 07:39:27 2016
|
Test program:
Code: | #include <18F67K90.H>
#fuses HSH, NOWDT
#use delay(clock=20M)
#use i2c(MASTER, FAST, SCL=PIN_C3, SDA=PIN_C4, FORCE_HW)
#define MCP7940_ADDRESS 0xDE
//=====================================
void main()
{
int8 address = 0x00;
i2c_speed(400000);
i2c_start();
i2c_write(MCP7940_ADDRESS);
i2c_write(address);
while(TRUE);
} |
|
|
|
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
|
Posted: Mon Mar 21, 2016 12:51 pm |
|
|
Hi,
yes, my compiler version is indeed still the same.
I use 5k pull-up resistors.
I use the LM75B, MCP7940N, MCP4726, all support 400KHz speed.
One of those hangs with i2c_write:
#use i2c(MASTER, FAST=400000, I2C1) and
#use i2c(MASTER, FAST, I2C1)
This works fine:
#use i2c(MASTER, FAST, SCL=PIN_C3, SDA=PIN_C4)
Regards,
Jack. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19562
|
|
Posted: Mon Mar 21, 2016 2:05 pm |
|
|
If you have four devices on the bus, 5K is much too large. Each device adds capacitance.
The version that works, is using software I2C. This changes two things. First software is unlikely to get to 400K. You ask for 400K, but using the software routines, at 20MHz, you will probably only get to perhaps around 250K. The second thing it changes is the voltage the PIC sees as Vih. The I2C uses I2C transceivers that require the voltage to get to 0.8*Vdd, the software instead uses the port transceivers that have a lower Vih.
You will not be meeting the required I2C transition times on the rising edges, using 5KR.
You have also not answered about the actual length of the bus.
Try 1K5, which is safely above the value allowed by the I2C current limit. |
|
|
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
|
Posted: Mon Mar 21, 2016 3:34 pm |
|
|
Hi Ttelmah,
Thank you very much!
What you explain to me, makes much sense.
The total physical length of the tracks on the PCB may be 10cm at maximum.
Regards,
Jack. |
|
|
JackB
Joined: 04 Mar 2016 Posts: 32 Location: Netherlands
|
|
Posted: Thu Mar 24, 2016 5:44 am |
|
|
Hi, I changed the pull-up resistors from 4k7 to 1k5.
It did not help, but I still think that is better.
This hangs i2c_write:
#use i2c(MASTER, FAST, I2C1)
And this works, it might be software i2c, though.
#use i2c(MASTER, FAST, SCL=PIN_C3, SDA=PIN_C4)
Thank you all for your help!
I think I don't bother this for now.
Although, with the help of all of you friends, I hoped to help other people who needed to use software i2c because hardware i2c doesn't work!
Regards,
Jack. |
|
|
|
|
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
|