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

PIC18F87J50 ADC value not correct??? (I think)
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
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PIC18F87J50 ADC value not correct??? (I think)
PostPosted: Mon Oct 14, 2013 9:17 am     Reply with quote

Hello,
CCS compiler version 4.119.
I have a ADC value 65472 when I put 2V at the ADC input...
I thought that with the settings I use that 3,3V was the maxium reading... So at 2V a reading from almost maxium is a little too much.......

Anybody a idea????

Regards,
Jody
Included the code:

Code:

#include "main_ADC.h"
#include "LCD_CCS.c"

int16 i;
unsigned int16 data;

#USE SPI (MASTER, SPI2, MODE=0, BITS=8, STREAM=SPI_2, MSB_FIRST)


void main()
{
   setup_adc_ports(sAN0|sAN1|sAN2|sAN3|sAN4|sAN7|sAN10|sAN11|VSS_VDD);
   setup_adc(ADC_CLOCK_DIV_2);


   
   setup_timer_1(T1_INTERNAL | T1_DIV_BY_8);
   set_timer1(0);
   setup_timer_2(T2_DIV_BY_16,255,1); // 819 us overflow, 819 us interrupt
   setup_timer_3(T3_INTERNAL|T3_DIV_BY_1);
   setup_timer_4(T4_DISABLED, 0, 1);
   setup_spi2(SPI_MASTER|SPI_XMIT_L_TO_H|SPI_SAMPLE_AT_MIDDLE|SPI_CLK_DIV_16);
   setup_comparator(NC_NC_NC_NC);// This device COMP currently not supported by the PICWizard

   lcd_init();

      while (TRUE)
   {
      set_adc_channel(11);
      delay_us(50);
      data = read_adc();
      lcd_gotoxy(1,1);
      printf(lcd_putc,"Adc channel = %02Ld", 11);
      lcd_gotoxy(21,1);
      printf(lcd_putc,"Adc value   = %Lu", data);
      delay_ms(100);
   }
}


Header file:
Code:

#include <18F87J50.h>
#device ICD=TRUE
#device adc=16

#FUSES DEBUG                    //Debug mode for use with ICD
#FUSES NOWDT                    //No Watch Dog Timer
#FUSES WDT128                   //Watch Dog Timer uses 1:128 Postscale
#FUSES NOSTVREN                 //Stack full/underflow will not cause reset
#FUSES NOXINST                  //Extended set extension and Indexed Addressing mode disabled (Legacy mode)
#FUSES FCMEN                //Fail-safe clock monitor enabled
#FUSES NOIESO                //Internal External Switch Over mode enabled
#FUSES MSSPMSK5
#FUSES NOEASHFT                 //Address shifting disabled
#FUSES NOPMPEMB
#FUSES CCP2C1
#FUSES ECPLL
#FUSES NOCPUDIV
#FUSES PLL1                    //Divide By 10(40MHz oscillator input)


#use delay(clock=40000000)
temtronic



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

View user's profile Send private message

PostPosted: Mon Oct 14, 2013 9:25 am     Reply with quote

I don't use that PIC and haven't read it's datasheet but I suspect the adc_clock divisor is wrong.
I'd check the 'valid adc settings' chart in the ADC section to see what's allowed for a 3V PIC running at 40 MHz.

Also check the PIC spec to be sure you can run it at 40MHz at 3 Volts.

Either of these two conditions could give you wrong results...

hth
jay
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PostPosted: Mon Oct 14, 2013 9:46 am     Reply with quote

When I use the internal oscillator at 4MHz and a
setup_adc(ADC_CLOCK_DIV_64| ADC_TAD_MUL_0);
I get the same result...
alan



Joined: 12 Nov 2012
Posts: 357
Location: South Africa

View user's profile Send private message

PostPosted: Mon Oct 14, 2013 10:57 am     Reply with quote

You have to set #device ADC= 8/10/12. Otherwise CCS the ADC are left justified instead of right.

Regards
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PostPosted: Mon Oct 14, 2013 11:49 am     Reply with quote

like in the header file the third line??
alan



Joined: 12 Nov 2012
Posts: 357
Location: South Africa

View user's profile Send private message

PostPosted: Mon Oct 14, 2013 12:06 pm     Reply with quote

Sorry missed that, but change to 10 bit, ADC are 10 bit on this chip.

Regards
Ttelmah



Joined: 11 Mar 2010
Posts: 19608

View user's profile Send private message

PostPosted: Mon Oct 14, 2013 12:40 pm     Reply with quote

One obvious comment. On this chip, Vss to Vdd, is _AVss_ to _AVdd_. Are these pins connected, and connected to 0v/3.3v. They need to be....

Best Wishes
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PostPosted: Tue Oct 15, 2013 4:57 am     Reply with quote

AVDD -> 3.3V (pin 25) AVSS -> GND (pin 26) it is a 80 pins device...

At this moment the ADV value is not moving at all.... it is stuck at 33423 no mather what I am connecting to the adc pin.....

Am i doing something wrong??? or is it broken???

Second test: Have another board.... run the same software as above...
ADC value on all channels is 63371....

Even when I ground one... the reading is 63371.

Regards,
Jody
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PostPosted: Tue Oct 15, 2013 6:44 am     Reply with quote

UPDATE:

I am trying to read AN11 at this moment (pin 14 F6) and after reading the registers has the following value (1V at the input):

Registers are:
ADCON0: 00101100 (0x2C)
that is reference AVSS to AVDD (GND to 3.3V),
Channel 11,
Conversion done,
AD Module disabled.
ADCON1: 00000000 (0x00)
left justified,
normal AD,
0 TAD,
FOSC/2.
ANCON0: 00000000 (0x00)
Analog channel.
ANCON1: 00000000 (0x00)
Analoge channel

Is this correct??? if so.. still no adc_data
Ttelmah



Joined: 11 Mar 2010
Posts: 19608

View user's profile Send private message

PostPosted: Wed Oct 16, 2013 1:25 am     Reply with quote

It has already been pointed out to you, that you are trying to clock the ADC much too fast.
Very first post from temtronic.

For a 40MHz device, the _maximum_ is Fosc/32, but you are still using Fosc/2....
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PostPosted: Wed Oct 16, 2013 1:42 am     Reply with quote

Oops sorry.. forgot to tell.. after the first message I picked a new board...
Used the internal oscilator on another board..... 8MHz...
But right now I have a 40MHz oscillator... and used the FOSC/64....

And the result are on all the channel the same...even when I left them float and when I connect 1V to the input...

Mine hair is turning grey......
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

Solved.... but why????
PostPosted: Wed Oct 16, 2013 5:04 am     Reply with quote

Okee what I have done:
Setting all the ADC related bits by hand.....
And then it starts working....
Anybody knows why????
Code:

#include "main_ADC.h"

unsigned int16   data0,data11;

#byte ADCON0       = 0xFC2
#bit VCFG1          = ADCON0.7
#bit VCFG0          = ADCON0.6
#bit CHS3          = ADCON0.5
#bit CHS2          = ADCON0.4
#bit CHS1         = ADCON0.3
#bit CHS0          = ADCON0.2
#bit ADCON0_GO       = ADCON0.1
#bit ADON          = ADCON0.0

#byte ADCON1       = 0xFC1
#bit ADFM          = ADCON1.7
#bit ADCAL         = ADCON1.6
#bit ACQT2         = ADCON1.5
#bit ACQT1         = ADCON1.4
#bit ACQT0         = ADCON1.3
#bit ADCS2         = ADCON1.2
#bit ADCS1         = ADCON1.1
#bit ADCS0         = ADCON1.0

void main()
{
   setup_timer_4(T4_DISABLED,0,1);
   setup_comparator(NC_NC_NC_NC);// This device COMP currently not supported by the PICWizard

   //****** Setup ADC ***//
   VCFG1       = 0;
   VCFG0       = 0;
   CHS3       = 0;
   CHS2       = 0;   
   CHS1      = 0;   
   CHS0       = 0;
   ADCON0_GO    = 0;   
   ADON       = 1;   
   
   ADFM       = 0;
   ADCAL      = 0;
   ACQT2      = 1;
   ACQT1      = 0;
   ACQT0      = 1;
   ADCS2      = 1;
   ADCS1      = 1;
   ADCS0      = 0;

   while (TRUE)
    {
      set_adc_channel(0);
      delay_ms(50);
      data0 = read_adc();
      delay_ms(10);

      set_adc_channel(11);
      delay_ms(50);
      data11 = read_adc();
      delay_ms(10);
    }
 }

Code:

#include <18F87J50.h>
 #device ICD=TRUE
 #device adc=10

 #FUSES DEBUG                    //Debug mode for use with ICD
 #FUSES NOWDT                    //No Watch Dog Timer
 #FUSES WDT128                   //Watch Dog Timer uses 1:128 Postscale
 #FUSES NOSTVREN                 //Stack full/underflow will not cause reset
 #FUSES NOXINST                  //Extended set extension and Indexed Addressing mode disabled (Legacy mode)
 #FUSES FCMEN                //Fail-safe clock monitor enabled
 #FUSES NOIESO                //Internal External Switch Over mode enabled
 #FUSES MSSPMSK5
 #FUSES NOEASHFT                 //Address shifting disabled
 #FUSES NOPMPEMB
 #FUSES CCP2C1
 #FUSES ECPLL
 #FUSES NOCPUDIV
 #FUSES PLL1                    //Divide By 10(40MHz oscillator input)


 #use delay(clock=40000000)
temtronic



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

View user's profile Send private message

PostPosted: Wed Oct 16, 2013 5:22 am     Reply with quote

well that's good news !!
Could be a compiler bug.
You should take your working program, copy it,save as 'ver2', edit to use the CCS ADC setup functions, compile and test. Then printout the listings to see what is different in the ADC setup configurations.

Please report back what you find, if it is a 'bug'( incorrect setup), contact CCS support and inform them.

hth
jay
gaugeguy



Joined: 05 Apr 2011
Posts: 306

View user's profile Send private message

PostPosted: Wed Oct 16, 2013 7:12 am     Reply with quote

You changed from ADC_TAD_MUL_0 to ADC_TAD_MUL_8 (ACQT2 = 1)
This gave the ADC the correct acquisition time to give a good result.
temtronic



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

View user's profile Send private message

PostPosted: Wed Oct 16, 2013 8:42 am     Reply with quote

gee... the old guy's first hunch was right !...

Jay
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