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

Input() On dsPIC33EP256GP502

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



Joined: 05 Jul 2010
Posts: 129

View user's profile Send private message

Input() On dsPIC33EP256GP502
PostPosted: Mon Mar 16, 2015 5:23 pm     Reply with quote

Hi,

I'm trying to read an Avago encoder via SPI on a dsPIC33EP256GP502.

I find when I disconnect the data line from the pic, I can see the encoder responding, but as soon as I reattach the PIC, the line stays at 0V.

My presumption is that something inside the PIC isn't being initialised correctly as I've verified the tris by explicitly setting it to 0xFFFF and checking the asm. Also, this pin seems to be a very heavily used one:
"TCK/CVREF1O/ASCL1/SDO1/RP40/T4CK/RB8".

For the moment, I'm bit banging the spi as I suspected there may be a spi register problem.

Could someone please have a look at my code and see if they concur as I can't see exactly why it isn't working.

Cheers,



Code:
CCS PCD C Compiler, Version 5.025, 16548     

               ROM used:   726 bytes (0%)
                           Largest free fragment is 65536
               RAM used:   139 (0%) at main() level
                           139 (0%) worst case
               Stack used: 2 locations
               Stack size: 128

*
00000:  GOTO    218
.................... 
.................... 
.................... 
.................... #include <33EP256GP502.h>
.................... //////// Standard Header file for the DSPIC33EP256GP502 device ////////////////
.................... #device DSPIC33EP256GP502
.................... 
.................... #list
.................... 
.................... 
.................... #fuses NOWDT,NOPROTECT, HS
.................... 
.................... #use delay(clock=70M, xtal=20M) // Actual crystal is 20M
*
00200:  CP0     W0
00202:  BTSC.B  42.1
00204:  BRA     216
00206:  REPEAT  #8B3
00208:  NOP     
0020A:  REPEAT  #3FFE
0020C:  NOP     
0020E:  REPEAT  #3FFE
00210:  NOP     
00212:  DEC     W0,W0
00214:  BRA     NZ,206
00216:  RETURN 
.................... 

.................... #define SPI_SS  PIN_B7
.................... 
.................... 
.................... 
.................... 
.................... void main() {
00218:  MOV     #8F80,W15
0021A:  MOV     #8FFF,W0
0021C:  MOV     W0,20
0021E:  NOP     
00220:  BSET.B  8C1.7
00222:  MOV     #46,W0
00224:  MOV.B   W0L,742
00226:  MOV     #57,W0
00228:  MOV.B   W0L,742
0022A:  BCLR.B  742.6
0022C:  MOV     #25,W0
0022E:  MOV     W0,6C4
00230:  MOV     #1,W0
00232:  MOV     W0,680
00234:  MOV     #46,W0
00236:  MOV.B   W0L,742
00238:  MOV     #57,W0
0023A:  MOV.B   W0L,742
0023C:  BSET.B  742.6
0023E:  MOV     #1,W4
00240:  MOV     W4,744
00242:  MOV     #13,W4
00244:  MOV     W4,746
00246:  DISI    #E
00248:  MOV     #103,W0
0024A:  MOV     #743,W1
0024C:  MOV     #78,W2
0024E:  MOV     #9A,W3
00250:  MOV.B   W2L,[W1]
00252:  MOV.B   W3L,[W1]
00254:  MOV.B   W0L,743
00256:  LSR     W0,#8,W0
00258:  MOV     #742,W1
0025A:  MOV     #46,W2
0025C:  MOV     #57,W3
0025E:  MOV.B   W2L,[W1]
00260:  MOV.B   W3L,[W1]
00262:  MOV.B   W0L,[W1]
00264:  CLR     1000
00266:  MOV     #8000,W4
00268:  MOV     W4,220
0026A:  MOV     #400,W4
0026C:  MOV     W4,222
0026E:  BCLR.B  220.3
00270:  MOV     #12,W4
00272:  MOV     W4,228
00274:  CLR.B   1002
00276:  CLR.B   1003
00278:  CLR.B   1004
0027A:  CLR.B   1005
0027C:  CLR.B   1006
0027E:  CLR     1008
00280:  CLR.B   1007
00282:  CLR     E0E
00284:  CLR     E1E
00286:  CLR.B   100A
....................     int8 i = 0x00;
....................     setup_adc_ports( NO_ANALOGS );
00288:  CLR     E0E
0028A:  CLR     E1E
....................     setup_adc(ADC_OFF);
0028C:  CLR     320
....................     setup_comparator(1, NC_NC);
0028E:  CLR     A84
....................     setup_comparator(2, NC_NC);
00290:  CLR     A8C
....................     setup_comparator(3, NC_NC);
00292:  CLR     A94
....................     setup_comparator(4, NC_NC);
00294:  CLR     A9C
....................     setup_vref(VREF_DISABLED);
00296:  CLR     A82
....................     delay_ms(100);
00298:  MOV     #64,W0
0029A:  CALL    200
....................     //output_float(PIN_B8);
....................     set_tris_b(0xFFFF);
0029E:  SETM    E10
....................     output_high(PIN_B9);
002A0:  BCLR.B  E11.1
002A2:  BSET.B  E15.1
....................     output_low(SPI_SS);
002A4:  BCLR.B  E10.7
002A6:  BCLR.B  E14.7
....................     delay_ms(100);
002A8:  MOV     #64,W0
002AA:  CALL    200
....................     while (TRUE) {
....................         for (i=0x00; i<33; i++) {
002AE:  CLR.B   100A
002B0:  MOV.B   100A,W0L
002B2:  SE      W0,W0
002B4:  MOV     #21,W4
002B6:  CP      W4,W0
002B8:  BRA     LE,2C8
....................             output_toggle(PIN_B9);
002BA:  BCLR.B  E11.1
002BC:  BTG.B   E15.1
....................             delay_us(5);
002BE:  REPEAT  #AD
002C0:  NOP     
002C2:  INC.B   100A
002C4:  GOTO    2B0
....................         }
....................         output_high(PIN_B9);
002C8:  BCLR.B  E11.1
002CA:  BSET.B  E15.1
....................         delay_us(40);
002CC:  REPEAT  #576
002CE:  NOP     
002D0:  GOTO    2AE
....................     }
.................... }
002D4:  PWRSAV  #0

Configuration Fuses:
   Word  3L: 008B   ICSP1 NOJTAG NODEBUG
          H: FF00 
   Word  4L: 00F8   NOALTI2C1 NOALTI2C2 WDTWIN_25%
          H: FF00 
   Word  5L: 007F   WPOSTS16 WPRES128 PLLWAIT WINDIS NOWDT
          H: FF00 
   Word  6L: 0066   HS NOOSCIO IOL1WAY CKSNOFSM
          H: FF00 
   Word  7L: 0080   FRC IESO
          H: FF00 
   Word  8L: 0003   NOWRT NOPROTECT
          H: FF00 
   Word  9L: 0000 
          H: FF00 
   Word 10L: 0000 
          H: FF00 
temtronic



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

View user's profile Send private message

PostPosted: Mon Mar 16, 2015 5:33 pm     Reply with quote

I don't use that PIC but as a general rule, you should disable any/all peripherals associated with the I/O pin you're using. IE if is has an ADC input, disable that, if it has comparator use, disable it, etc.
Also it's a good idea to just 'toggle' the I/O pin, say at 1 HZ to confirm it's the correct pin, especially if the PIC you're using has 'programmable pins' !
This will also confirm the correct selection of clock speed, dividers, etc.

Jay
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Mar 16, 2015 6:20 pm     Reply with quote

Post the p/n of your Avago encoder.

Post a list of all connections between the PIC board and the encoder.

Describe your test. Are you testing "hot plugging" of the cable between
the encoder and the PIC board ? Are you yanking the cable in the
middle of an on-going SPI transaction, and the re-plugging it and hoping
the transaction will continue where it left off ?

Are you only disconnecting the SDI line coming into the PIC, or are you
disconnecting other lines at the same time (SCK, CS, power, etc.) ?

Do you have any pull-up or pull-down resistors on the PIC board, on
any of the lines that you are yanking ?
Geps



Joined: 05 Jul 2010
Posts: 129

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 12:28 am     Reply with quote

Quote:
I don't use that PIC but as a general rule, you should disable any/all peripherals associated with the I/O pin you're using. IE if is has an ADC input, disable that, if it has comparator use, disable it, etc.
Also it's a good idea to just 'toggle' the I/O pin, say at 1 HZ to confirm it's the correct pin, especially if the PIC you're using has 'programmable pins' !
This will also confirm the correct selection of clock speed, dividers, etc.

Jay

Thanks Jay,

Yes sorry, I have already done that. At least I've explicitly disabled everything I can see that I can disable, whether on that pin or not.

Clock speed etc is all good and I can printf with no problems.

Quote:

Post the p/n of your Avago encoder.


AEAT-6600-T16
http://www.avagotech.com/pages/en/motion_control_encoder_products/magnetic_encoders/aeat-6600-t16/

Quote:

Post a list of all connections between the PIC board and the encoder.


See below

Quote:

Describe your test. Are you testing "hot plugging" of the cable between
the encoder and the PIC board ? Are you yanking the cable in the
middle of an on-going SPI transaction, and the re-plugging it and hoping
the transaction will continue where it left off ?


Due to the required precision of the magnet above the encoder, I've got my own pcb with PIC on one side and encoder on the reverse.

I power the device up, and it holds the SS line low (I'm using the 2 wire SSI mode - essentially you just keep CS low) and then the PIC generates the clock signal. My logic analyser shows the clock and SS lines at the values I expect but the (bidirectional) data line as flat with very brief intermittent noise (1us pulse every 10-20seconds).

I cut the data line track leaving the encoder's pin floating, redo my test and can now see the encoder replying to the clock signal. This is consistent when repeated (3 times so far) - as soon as the PIC is disconnected, the line goes high/low as I'd expect to see.

Quote:

Are you only disconnecting the SDI line coming into the PIC, or are you
disconnecting other lines at the same time (SCK, CS, power, etc.) ?


As above, 1 track cut, nothing more.

Quote:

Do you have any pull-up or pull-down resistors on the PIC board, on
any of the lines that you are yanking ?


This is an explanation of the encoder's pins voltages and what's attached to them:
Code:

Pin  Name    Voltage   Notes
 1 - A/U     3.261     Not Connected
 2 - B/V     3.267     NC
 3 - I/W     3.270     NC
 4 - MAG HI  0.016     47K Pull down
 5 - MAG LO  ~0.016    from memory when tested with magnet 47K Pull down
 6 - GND     0.013   
 7 - ALIGN   0.020     47K Pull down
 8 - PWM     0.020     NC
 9 - VDD     3.288     10uf decoupled
10 - VDD_F   3.290     100nf decoupled (tied to VDD rail)
11 - PWRDOWN 0.030     47K Pull down
12 - VPP     3.291     100nf decoupled
13 - PROG    0.016     47K Pull down
14 - NCS     0.244     Connected to PIC
15 - CLK     1.914     Connected to PIC, 47K pull down
16 - DO/DI   0.242     Connected to PIC.


PIC has 10K pullup on MCLR, 10uF VCap and 20MHz crystal oscillator - all other pins are unpopulated since I stripped everything back.

Cheers,
Geps



Joined: 05 Jul 2010
Posts: 129

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 12:31 am     Reply with quote

Current test program:

Code:

#fuses NOWDT,NOPROTECT, HS, ICSP3

#use delay(clock=70M, xtal=20M)

#define SPI_SS  PIN_B7
#PIN_SELECT U1TX=PIN_A4
#PIN_SELECT U1RX=PIN_B5

#use rs232(STREAM=RX_SERIAL, XMIT=PIN_B4, RCV=PIN_B3, baud=115200, ERRORS, UART1)

void main() {
    int8 i = 0x00;
    setup_adc_ports( NO_ANALOGS );
    setup_adc(ADC_OFF);
    setup_comparator(1, NC_NC);
    setup_comparator(2, NC_NC);
    setup_comparator(3, NC_NC);
    setup_comparator(4, NC_NC);
    setup_vref(VREF_DISABLED);
    delay_ms(100);
    //output_float(PIN_B8);
    set_tris_b(0xFFFF);
    output_high(PIN_B9);
    output_low(SPI_SS);
    delay_ms(100);
    while (TRUE) {
        for (i=0x00; i<33; i++) {
            //fprintf(RX_SERIAL, "Started\n");
            output_toggle(PIN_B9);
            delay_us(5);
        }
        output_high(PIN_B9);
        delay_us(40);
    }
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19592

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 2:23 am     Reply with quote

Don't fiddle about, use the SPI library:
Code:

#define SPI_SEL PIN_B7
#define SPI_CLK PIN_B9
#define SPI_DATA //You don't tell us what pin this is....

#use spi(MODE=3, BAUD=1MHz, CLK=SPI_CLK, DI=SPI_DATA, ENABLE=SPI_SEL, BITS=16, ENABLE_DELAY=1, STREAM=AV02)

#use rs232(STREAM=RX_SERIAL, XMIT=PIN_B4, RCV=PIN_B3, baud=115200, ERRORS, UART1)

void main() {
    unsigned int16 data;
    setup_adc_ports( NO_ANALOGS );
    setup_adc(ADC_OFF);
    setup_comparator(1, NC_NC);
    setup_comparator(2, NC_NC);
    setup_comparator(3, NC_NC);
    setup_comparator(4, NC_NC);
    setup_vref(VREF_DISABLED);
    output_high(SPI_SEL);
    output_high(SPI_CLK); //ensure pins are inactive
    delay_ms(100); //10mSec minimum required

    while (TRUE)
    {
        data = SPI_XFER(AV02, 0,16); //transfer 16 bits
        fprintf(UART1,"Data %04LX\n\r",data);
        delay_ms(100);
    }
}

You seem to be trying to clock 16.5 bits (toggling 0 to 32) - the chip returns 16bits, with the select line permanently low. You can do this (2 wire interface mode), but you are dangerously close (under....) the minimum clock rate specified for the chip (10uSec per cycle).
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 5:27 am     Reply with quote

Quote:
#define SPI_DATA //You don't tell us what pin this is....

Appears to be B8.

I'm no expert on the dspic33s, but as far as I understand it, that's one of the alternative SPI data output from the PIC (SDO). As the sensor is always outputting, to have any chance of using the hardware SPI you need to wire it to an SPI data input, SDI.

What you are seeing is a hardware clash - something in the PIC is driving B8 low, clashing with the sensor also driving it. Therefore one of B8s functions is not turned off. I don't know which function. You need to check all its possible functions and turn off, or relocate, the corresponding peripherals.

SPI does not usually work with bidirectional signals (note the sensor data sheet calls it SSI...), but there is no SPI standard, and bi-directional is sometimes used, probably to save a pin. In this case, input is probably only used during configuration. Once configured the sensor only ever outputs on the pin. The CCS C SPI code doesn't seem to have a bi-direction mode, and so doesn't support it. But it doesn't need to, it just needs to receive data from the sensor. There's no real reason why the PIC's hardware SPI cannot be used, and none for not using CCS C's support for both hard and soft SPI. Just find out what other function is driving the pin, or better yet, use an SDI (input) rather than SDO (output) pin and use the compiler's SPI functions.
Geps



Joined: 05 Jul 2010
Posts: 129

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 6:57 am     Reply with quote

Ttelmah wrote:
Don't fiddle about, use the SPI library:

You seem to be trying to clock 16.5 bits (toggling 0 to 32) - the chip returns 16bits, with the select line permanently low. You can do this (2 wire interface mode), but you are dangerously close (under....) the minimum clock rate specified for the chip (10uSec per cycle).


Thanks Ttelmah,

I'm pretty sure though the maximum clock period is 20us per cycle, at least that's what I got from the datasheet so I should be well within it. The 0.5 clock bit is because the clock needs to stay high inbetween reads so the encoder can load new data.

Will try the code you posted later when I have the hardware to hand and report back.



RF_Developer wrote:
Quote:
#define SPI_DATA //You don't tell us what pin this is....

Appears to be B8.

I'm no expert on the dspic33s, but as far as I understand it, that's one of the alternative SPI data output from the PIC (SDO). As the sensor is always outputting, to have any chance of using the hardware SPI you need to wire it to an SPI data input, SDI.

What you are seeing is a hardware clash - something in the PIC is driving B8 low, clashing with the sensor also driving it. Therefore one of B8s functions is not turned off. I don't know which function. You need to check all its possible functions and turn off, or relocate, the corresponding peripherals.

SPI does not usually work with bidirectional signals (note the sensor data sheet calls it SSI...), but there is no SPI standard, and bi-directional is sometimes used, probably to save a pin. In this case, input is probably only used during configuration. Once configured the sensor only ever outputs on the pin. The CCS C SPI code doesn't seem to have a bi-direction mode, and so doesn't support it. But it doesn't need to, it just needs to receive data from the sensor. There's no real reason why the PIC's hardware SPI cannot be used, and none for not using CCS C's support for both hard and soft SPI. Just find out what other function is driving the pin, or better yet, use an SDI (input) rather than SDO (output) pin and use the compiler's SPI functions.


Yes, I agree it's a hardware clash, but I can't be sure which hardware exactly as from my understanding they are all off either implied or explicitly:

The pin also has on it:
TCK - JTAG has been disabled in the fuse section
CVREF1O - All comparator's have been explicitly set to off
ASCL1 - I2C is unused (is there an explicit switch off command?)
SDO1 - SPI1 is unused (is there an explicit switch off command?)
RP40 - no PPS functions have been set
T4CK - Timer 4 is unused (again, is there an explicit switch off command?)
RB8

The plan was to use the SPI hardware but SPI2 which is remappable with the PPS function...it's just unfortunate that it's over the top of the pins for SPI 1 but as I said, there wasn't room to run the tracks as I wanted to use SPI1 as it works.

Cheers,
temtronic



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

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 8:22 am     Reply with quote

Might need to dump the listing and compared the actual fuses and registers set to disable 'things' as it might be the compiler version sets the wrong bits.

You'll have to 'play computer' and compare what was coded versus what's in the datasheets.

Jay
Geps



Joined: 05 Jul 2010
Posts: 129

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 12:17 pm     Reply with quote

I've had a look through and I can't see any registers getting set that would cause what I'm seeing...on the assumption that they are starting up with the 0x0000 value it states in the datasheet.

I've tried Ttelmah's code and it generates the same results as I had before - activity on the data line when disconnected, changing to a flat 0V when the pic is connected.

I'm going to try a new set of hardware just to rule out anything from that perspective and see if that shines any light on the problem.
Ttelmah



Joined: 11 Mar 2010
Posts: 19592

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 12:35 pm     Reply with quote

The timeout behaviour occurs at 20uSec, but the minimum clock speed is specified at 100KHz.

The SPI is not bi-directional. It's like half duplex serial. For receive only, you can ignore the transmission side.

None of the other things on these pins should affect anything. JTag is disabled, which is the only connection that would cause problems.

I'd step back. Leave the chip disconnected and verify that you can toggle each pin used for this interface. Then test you can read an input on each pin. There shouldn't be data output by the chip, unless the clock is actually operating.
Geps



Joined: 05 Jul 2010
Posts: 129

View user's profile Send private message

PostPosted: Tue Mar 17, 2015 4:10 pm     Reply with quote

Thanks Ttelmah,

Turns out it was the PIC that was faulty. Recreated the circuit with new components on another PCB and it worked first time.

Thanks for the suggestions,

Cheers,
Ttelmah



Joined: 11 Mar 2010
Posts: 19592

View user's profile Send private message

PostPosted: Wed Mar 18, 2015 1:07 am     Reply with quote

Well done.

This is why 'stepping back' is one of the most powerful tools.
Just had it yesterday, with new code for a customer, that wouldn't work. Fortunately, they use the same basic board for another project for which I had working code, so I asked them to put this code into the board. Lo and behold, this 'known working' code, gave exactly the same fault....
Pointed this out, and suggested they got the hardware working first. Smile

Often I'll spend the time to make an 'infantile' test program, that just operates lines, and reads lines, to verify the hardware is working, before even starting on the main code.
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