|
|
View previous topic :: View next topic |
Author |
Message |
geetha rangasamy
Joined: 24 Feb 2016 Posts: 5
|
Problem in working with SPI |
Posted: Fri Feb 26, 2016 2:57 am |
|
|
My target is to interface MIFARE reader to perform Read/Write by using SPI protocol.
For that, I desired to interface DS1307 RTC first. In that, i have some minor problem to deal with it.
So, I attached my code below. Please notify me if any mistake in this code.
Code: |
#include<16f877a.h>
#fuses HS,NOWDT
#use delay (clock=8mhz)
#use spi(DI=PIN_B3, DO=PIN_B2, CLK=PIN_B1, ENABLE=PIN_B0, BITS=16)
#use rs232(baud=9600,xmit=PIN_b7,rcv=PIN_b6)
byte i = 0x80;
byte out;
void main() {
while(TRUE)
{
spi_xfer(i);
out = spi_xfer(i);
delay_ms(100);
}
}
|
I got the output from Proteus oscilloscope window.
CS pin going to low. At that time clock is generated. MOSI data is something generated and send it to slave.
But the MISO line did not send back any data to master.
(I am sending 0x80 command to slave for read the seconds from the RTC chip).
CPU--->DS3234
B0----->CS
B1----->Clock
B2----->DI
B3<-----DO
Please someone help me.....
What i am doing right now?
What i need to change the above code? |
|
|
RF_Developer
Joined: 07 Feb 2011 Posts: 839
|
|
Posted: Fri Feb 26, 2016 4:04 am |
|
|
The DS1307 is an I2C device, not SPI!
I beleive a driver/example code is almost certainly available in CCS for the DS1307. This should save you a lot of work. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19605
|
|
Posted: Fri Feb 26, 2016 4:06 am |
|
|
Get rid of the enable in the #USE SPI.
It is better to handle this yourself.
The way a 'read' has to happen, is that you clock an _8bit_ control/address into the chip, and then clock the reply back.
So:
Code: |
#include<16f877a.h>
#fuses HS,NOWDT
#use delay (clock=8mhz)
#use spi(DI=PIN_B3, DO=PIN_B2, CLK=PIN_B1, MODE=1)
//chip supports mode 1 & mode 3
#use rs232(baud=9600,xmit=PIN_b7,rcv=PIN_b6)
#define SECONDS_READ 0x00
#define SECONDS_WRITE 0x80
#define CS PIN_B0
void main()
{
int8 rval;
output_high(CS); //ensure CS starts high
delay_ms(10);
while(TRUE)
{
output_low(CS); //drop the select
rval=spi_xfer(SECONDS_READ,8); //clock out the read command
rval= spi_xfer(0,8); //clock out eight dummy bits and receive reply
output_high(CS); //finish the transaction
delay_ms(100);
}
}
|
The "W/R" bit needs to be _low_ for a read. 0x80, is the write address for the seconds register.
By operating CS yourself, you can decide (for instance), to send a ten byte command as one transaction, to configure the chip.
Are you using a DS1307, or a DS3234?. The former is I2C, not SPI. |
|
|
geetha rangasamy
Joined: 24 Feb 2016 Posts: 5
|
|
Posted: Fri Feb 26, 2016 4:48 am |
|
|
Ttelmah wrote: | Get rid of the enable in the #USE SPI.
It is better to handle this yourself.
The way a 'read' has to happen, is that you clock an _8bit_ control/address into the chip, and then clock the reply back.
So:
Code: |
#include<16f877a.h>
#fuses HS,NOWDT
#use delay (clock=8mhz)
#use spi(DI=PIN_B3, DO=PIN_B2, CLK=PIN_B1, MODE=1)
//chip supports mode 1 & mode 3
#use rs232(baud=9600,xmit=PIN_b7,rcv=PIN_b6)
#define SECONDS_READ 0x00
#define SECONDS_WRITE 0x80
#define CS PIN_B0
void main()
{
int8 rval;
output_high(CS); //ensure CS starts high
delay_ms(10);
while(TRUE)
{
output_low(CS); //drop the select
rval=spi_xfer(SECONDS_READ,8); //clock out the read command
rval= spi_xfer(0,8); //clock out eight dummy bits and receive reply
output_high(CS); //finish the transaction
delay_ms(100);
}
}
|
The "R/W" bit needs to be _low_ for a read. 0x80, is the write address for the seconds register.
By operating CS yourself, you can decide (for instance), to send a ten byte command as one transaction, to configure the chip.
Are you using a DS1307, or a DS3234?. The former is I2C, not SPI. |
Quote: | Executing: "C:\Program files\Picc\CCSC.exe" +FM "spi1.c" #__DEBUG=1 +ICD +DF +LN +T +A +M +Z +Y=9 +EA #__16F877A=TRUE
*** Error 51 "spi1.c" Line 40(35,36): A numeric expression must appear here
*** Error 51 "spi1.c" Line 41(25,26): A numeric expression must appear here
2 Errors, 0 Warnings.
Build Failed.
Halting build on first failure as requested.
BUILD FAILED: Fri Feb 26 16:12:19 2016
|
I got this error sir.
Thank you for replying.
I already using ds1307.
Now i need to interface RFID Reader That is MFCR522 NXP chip. Before using this chip I need to know the spi. so that is why I am interfacing DS3234 SPI RTC chip.
My questions
1.What is the mode ? I read a lot about spi from websites that has mentioned about CLOCK PHASE and CLOCK POLARITY what is this ?.
2.The compiler help said like this
int i = 34;
spi_xfer(i);
// transfers the number 34 via SPI
int trans = 34, res;
res = spi_xfer(trans);
// transfers the number 34 via SPI
// also reads the number coming in from SPI
But you pass the two values separated by comma in this function like this rval=spi_xfer(SECONDS_READ,8);
this two values
(SECONDS_READ,8)
3. Again you pass the same value but in different method why you make two lines
rval=spi_xfer(SECONDS_READ,8); //clock out the read command
rval= spi_xfer(0,8); //clock out eight dummy bits and receive reply
I am totally confused with two lines.
And I purchased the MFRC522 RFID reader here
http://www.alselectro.com/rfid-13.56mhz--mifair-read-write-with-rc522-chip.html
After finish this DS3234 I will interface this RFID Reader.
Thank you again. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19605
|
|
Posted: Fri Feb 26, 2016 5:42 am |
|
|
Apologies, forgot you cannot use transfer lengths, without using a stream. You need:
Code: |
#include<16f877a.h>
#fuses HS,NOWDT
#use delay (clock=8mhz)
#use spi(DI=PIN_B3, DO=PIN_B2, CLK=PIN_B1, MODE=1, STREAM=SPI)
//chip supports mode 1 & mode 3
#use rs232(baud=9600,xmit=PIN_b7,rcv=PIN_b6)
#define SECONDS_READ 0x00
#define SECONDS_WRITE 0x80
#define CS PIN_B0
void main()
{
int8 rval;
output_high(CS); //ensure CS starts high
delay_ms(10);
while(TRUE)
{
output_low(CS); //drop the select
rval=spi_xfer(SPI,SECONDS_READ,8); //clock out the read command
rval= spi_xfer(SPI,0,8); //clock out eight dummy bits and receive reply
output_high(CS); //finish the transaction
delay_ms(100);
}
}
|
For some reason they only allow the number of bits to be specified, when a stream is selected, rather than when a default is selected. |
|
|
ezflyr
Joined: 25 Oct 2010 Posts: 1019 Location: Tewksbury, MA
|
|
Posted: Fri Feb 26, 2016 7:22 am |
|
|
Hi,
Man, what a confusing thread this is!
This is probably a textbook case on how not to ask for help on the forum! You prominently mention the DS1307 RTC (which is I2C) in a thread about problems with SPI, and in one teeny, tiny comment, also mention the DS3234 (which is SPI). You really need to use more clarity in your help requests!
Who's on first?: https://www.youtube.com/watch?v=kTcRRaXV-fg _________________ John
If it's worth doing, it's worth doing in real hardware! |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9282 Location: Greensville,Ontario
|
|
Posted: Fri Feb 26, 2016 8:09 am |
|
|
guess I'm getting used these 'interesting' posts...
1) please post a 'link' to the MIFARE reader. This information is vital if you want us to help
2) do NOT use PROTEUS. We can't help you with it. It's well known to have major flaws, errors and faulty DRCs. Be aware that just becuse 'it works' in PROTEUS it probably won't in the real world !
3) the 877 is a 5 volt PIC, is the MIFARE a 5 volt device or 3 volt?
Jay |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Fri Feb 26, 2016 3:17 pm |
|
|
Quote: | 1.What is the mode ? I read a lot about spi from websites that has
mentioned about CLOCK PHASE and CLOCK POLARITY what is this ?. |
Read these webpages:
http://dlnware.com/theory/SPI-Transfer-Modes
http://www.totalphase.com/support/articles/200349236-SPI-Background#modes
Quote: | 2.The compiler help said like this
int i = 34;
spi_xfer(i);
// transfers the number 34 via SPI
int trans = 34, res;
res = spi_xfer(trans);
// transfers the number 34 via SPI
// also reads the number coming in from SPI
But you pass the two values separated by comma in this function like this rval=spi_xfer(SECONDS_READ,8); |
Ttelmah likes to use an optional method, where the number of bits to
be transferred is specified in the 2nd parameter. You don't have to
do it that way. If you want to use the method shown in the Compiler Help,
then specify the number of bits in the #use spi() statement, as shown
in bold below:
Quote: | #use spi(DI=PIN_B3, DO=PIN_B2, CLK=PIN_B1, MODE=1, BITS=8) |
Quote: | Again you pass the same value but in different method why you make two lines
rval=spi_xfer(SECONDS_READ,8); //clock out the read command
rval= spi_xfer(0,8); //clock out eight dummy bits and receive reply |
Look in the DS3234 data sheet on page 18, at this diagram:
Quote: | Figure 4. SPI Single-Byte Read |
http://datasheets.maximintegrated.com/en/ds/DS3234.pdf
It shows two sequential 8-bit transfers. The first transfer writes the
register address and the 2nd transfer reads the register data.
The comments that Ttelmah put on the two statements show this.
If you add BITS=8 to the #use spi() statement, you can do it like this:
Code: |
output_low(CS);
spi_xfer(SECONDS_READ); // Write the register address
rval = spi_xfer(0); // Read data from the specified register
output_high(CS);
|
After these lines execute, 'rval' will have the value of the Seconds
register in it. |
|
|
geetha rangasamy
Joined: 24 Feb 2016 Posts: 5
|
MIFARE Reader help |
Posted: Sat Feb 27, 2016 3:10 am |
|
|
temtronic wrote: | guess I'm getting used these 'interesting' posts...
1) please post a 'link' to the MIFARE reader. This information is vital if you want us to help
2) do NOT use PROTEUS. We can't help you with it. It's well known to have major flaws, errors and faulty DRCs. Be aware that just becuse 'it works' in PROTEUS it probably won't in the real world !
3) the 877 is a 5 volt PIC, is the MIFARE a 5 volt device or 3 volt?
Jay |
I am using PIC at 5.0v and MIFARE Reader at 3.3v
We designed power supply by using 3.3v regulator(1117).
I am purchasing and using the MIFARE reader by the follwing link:
http://www.alselectro.com/rfid-13.56mhz--mifair-read-write-with-rc522-chip.html
It has the pins below,
1)SDA
2)SCK
3)MOSI
4)MISO
5)IRQ
6)GND
7)RST
8)3.3v |
|
|
geetha rangasamy
Joined: 24 Feb 2016 Posts: 5
|
Thank you for reply |
Posted: Sat Feb 27, 2016 3:13 am |
|
|
Ttelmah wrote: | Apologies, forgot you cannot use transfer lengths, without using a stream. You need:
Code: |
#include<16f877a.h>
#fuses HS,NOWDT
#use delay (clock=8mhz)
#use spi(DI=PIN_B3, DO=PIN_B2, CLK=PIN_B1, MODE=1, STREAM=SPI)
//chip supports mode 1 & mode 3
#use rs232(baud=9600,xmit=PIN_b7,rcv=PIN_b6)
#define SECONDS_READ 0x00
#define SECONDS_WRITE 0x80
#define CS PIN_B0
void main()
{
int8 rval;
output_high(CS); //ensure CS starts high
delay_ms(10);
while(TRUE)
{
output_low(CS); //drop the select
rval=spi_xfer(SPI,SECONDS_READ,8); //clock out the read command
rval= spi_xfer(SPI,0,8); //clock out eight dummy bits and receive reply
output_high(CS); //finish the transaction
delay_ms(100);
}
}
|
For some reason they only allow the number of bits to be specified, when a stream is selected, rather than when a default is selected. |
I am using PIC at 5.0v and MIFARE Reader at 3.3v
We designed power supply by using 3.3v regulator(1117).
I am purchasing and using the MIFARE reader by the follwing link:
http://www.alselectro.com/rfid-13.56mhz--mifair-read-write-with-rc522-chip.html
It has the pins below,
1)SDA
2)SCK
3)MOSI
4)MISO
5)IRQ
6)GND
7)RST
8)3.3v |
|
|
geetha rangasamy
Joined: 24 Feb 2016 Posts: 5
|
SPI HELP |
Posted: Sat Feb 27, 2016 3:18 am |
|
|
ezflyr wrote: | Hi,
Man, what a confusing thread this is!
This is probably a textbook case on how not to ask for help on the forum! You prominently mention the DS1307 RTC (which is I2C) in a thread about problems with SPI, and in one teeny, tiny comment, also mention the DS3234 (which is SPI). You really need to use more clarity in your help requests!
Who's on first?: https://www.youtube.com/watch?v=kTcRRaXV-fg |
I apologize, we need SPI (DS3234) only... |
|
|
|
|
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
|