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

16f1503 to 16f676 conversion

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



Joined: 08 Sep 2011
Posts: 202

View user's profile Send private message

16f1503 to 16f676 conversion
PostPosted: Sat Jul 01, 2017 7:08 am     Reply with quote

hi everyone
Today I'm facing problem with 16f676 adc reading.
Actually i want convert micro controller. That code works fine with 16f1503 but when i convert it 16f676, adc readind reading function not work.

16f1503.h
Code:

#include <16F1503.h>
#device ADC=11

//#FUSES WDT                      //Watch Dog Timer
#FUSES NOMCLR                   //Master Clear pin used for I/O
#FUSES PROTECT                  //Code protected from reads
#FUSES BORV25                   //Brownout reset at 2.5V
#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O

#use delay(internal=4000000,restart_wdt)
//#use rs232(baud=9600,parity=N,xmit=PIN_C4,rcv=PIN_C3,bits=8,stream=PORT1)

#use FIXED_IO( A_outputs=PIN_A5,PIN_A2,PIN_A1 )
#use FIXED_IO( C_outputs=PIN_C5,PIN_C3,PIN_C2,PIN_C1,PIN_C0 )
volatile unsigned int16 system_tick=0;
unsigned int16 timer_adc_value;
long ac_voltage,lcutoff,hcutoff;
static unsigned char relay_status=0,relay_flag=0,timer_short_flag=0;
volatile unsigned char high_cutoff_flag=0,timer_led1_toggle_flag=0;
volatile unsigned char low_cutoff_flag=0; //added
unsigned char led2_toggle_flag = 0,timer_flag=0;
long read_ac_voltage(void);
long read_timer_value(void);
void relay_voltage(void);
void timer_delay(void);
void init_peripheral(void);

void auto_adjust_relay(void);


16f1503.c
Code:

#include <stablizer_1503.h>

#include <math.h>

void main()
{
   
init_peripheral();
/******Timer Init*******/
     
      output_low(RLY1_TMR); output_low(High_Low_LED);output_low(TIMER_LED);
      setup_timer_1(T1_INTERNAL|T1_DIV_BY_8); //524 ms overflow
      enable_interrupts(INT_TIMER1);
      enable_interrupts(GLOBAL);
      delay_ms(1);     
/******* End of ADC Init*******/ 

/******* Start of Peripherial *******/
     
      output_high(Buzzer);output_low(TIMER_LED);output_low(RLY1_TMR);
      output_low(RLY2);output_low(RLY3);output_low(RLY4);output_low(RLY5);
      output_low(High_Low_LED);
      system_tick = 0;
   
   /******* End of Peripherial *******/
   delay_ms(10);
   relay_voltage();  output_low(Buzzer);
  while(TRUE)       //Master Loop
   {   ///to do something
}}
/*****************************************/
//Reading A/C Voltage
/*****************************************/

long read_ac_voltage(void)
{
unsigned char i;
long adc_value;
long peak_value=0;

set_adc_channel(0);
delay_ms(1);
         for(i=0;i<=40;i++)
         {
            adc_value = read_adc();
            if(adc_value > peak_value)
            {
             peak_value = adc_value;
            }
           
            delay_us(500);
           
         }
         
         peak_value = (peak_value*0.266);
         return peak_value;
}


long read_timer_value(void)
{

            long adc_value;
            set_adc_channel(3);
            delay_ms(1);
            adc_value = read_adc();
            return adc_value;
   
}


Now pls guide for 16f676 !!!!!!!
_________________
sahu
temtronic



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

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 8:01 am     Reply with quote

hmm...
this
#device ADC=11

is probably wrong, most PIC ADCs are either 8 or 10 bits....never seen an 11 bit....

You don't say what is the 'problem' so

cut a new program,ONLY setup/read ADC/display data/loop say 1Hz.

Is the new PIC pin compatible and using the same PCB or a new PCB ? could be wiring error?

sampling 40x is not needed, better to do 32 ( faster and easier )

Jay
sahu77



Joined: 08 Sep 2011
Posts: 202

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 8:35 am     Reply with quote

temtronic wrote:
hmm...
this
#device ADC=11
is probably wrong, most PIC ADCs are either 8 or 10 bits....never seen an 11 bit....
You don't say what is the 'problem' so

sir i do that before
Code:
/#include <16F1503.h>
//#device ADC=11

#include <16F676.h>
#device ADC=10
/*
//#FUSES WDT                      //Watch Dog Timer
#FUSES NOMCLR                   //Master Clear pin used for I/O
#FUSES PROTECT                  //Code protected from reads
//#FUSES BORV25                   //Brownout reset at 2.5V
//#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
**/
//#FUSES WDT                    //No Watch Dog Timer
#FUSES INTRC_IO                 //Internal Oscillator @ 4 Mhz
//#FUSES BROWNOUT               //No brownout reset
#FUSES NOMCLR              //No brownout reset
#FUSES PROTECT          //Code protected from reads

//#use delay(internal=4000000,restart_wdt)
//#use rs232(baud=9600,parity=N,xmit=PIN_C4,rcv=PIN_C3,bits=8,stream=PORT1)
#use delay(clock=4000000)      // 4 Mhz Clock
#rom 0x3FF = {0x3480}


temtronic wrote:
]
cut a new program,ONLY setup/read ADC/display data/loop say 1Hz.
Is the new PIC pin compatible and using the same PCB or a new PCB ? could be wiring error?

all pin are same need only change micro controller


Quote:
sampling 40x is not needed, better to do 32 ( faster and easier )

not getting what want u say ?
_________________
sahu
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 10:26 am     Reply with quote

Where are the following functions in your program ? They're not there.
You are missing them:
Code:

setup_adc_ports()
setup_adc()

Look in the 16F1503.h file to see what parameters you can use with
those functions.
sahu77



Joined: 08 Sep 2011
Posts: 202

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 11:21 am     Reply with quote

PCM programmer wrote:
Where are the following functions in your program ? They're not there.
You are missing them:
Code:

setup_adc_ports()
setup_adc()

Look in the 16F1503.h file to see what parameters you can use with
those functions.

That's already in code.
But my mistake,
I have not post here !!
In the 16f1503 that part is:
Code:
void init_peripheral(void)
{
   
   set_tris_a(0x08); // RA3 TMR_relay reset
   set_tris_c(0x10); // RC4 reset
   
   /*******ADC*******/
   setup_comparator(NC_NC_NC_NC);
   setup_adc(ADC_CLOCK_DIV_32);
   setup_adc_ports( sAN0|sAN3| VSS_VDD);    //RA4 as timer value adc
   setup_comparator(NC_NC_NC_NC);
   set_tris_c(0x10);  // Set Pin RC4 as input, Timer reset
   port_a_pullups(0x08);//pull up on port a3
   port_c_pullups(0x10);//pull up on port c4

   /******* End of ADC Init*******/
}


but 16f676 has need
Code:
   //port_c_pullups(0x10);

because when choose 16f676 and complied as
Quote:
port_c_pullups(0x10);

I get error no 12.
Undefined identifier ...port_c_pullups

_________________
sahu
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 11:42 am     Reply with quote

Because the 676, does not offer pull-ups on port C.

This is a 'read the data sheet' one. You can only use abilities the chip actually has.
sahu77



Joined: 08 Sep 2011
Posts: 202

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 11:45 am     Reply with quote

Ttelmah wrote:
Because the 676, does not offer pull-ups on port C.

This is a 'read the data sheet' one. You can only use abilities the chip actually has.

ok thank you for information.
Pls also mention next problem.
_________________
sahu
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 1:55 pm     Reply with quote

What you are posting cannot compile.

First it has an impossible ADC number of bits. The compiler will error on this, and refuse to compile. Then it has no port setup. You then add these. However it means that code you are are actually posting has not been used on the PIC16F1503. Similarly you show 'port_c_pullups(0x10)'. Though it won't complain this won't do what you think. On the 1503, the port_c_pullups function accepts only a TRUE/FALSE value, so not giving a pull-up on C4, but on all the port C pins...

You need to start with code that works, to have any hope of porting it to another processor. Sad
sahu77



Joined: 08 Sep 2011
Posts: 202

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 2:45 pm     Reply with quote

Ttelmah wrote:
What you are posting cannot compile.

First it has an impossible ADC number of bits. The compiler will error on this, and refuse to compile. Then it has no port setup. You then add these. However it means that code you are are actually posting has not been used on the PIC16F1503. Similarly you show 'port_c_pullups(0x10)'. Though it won't complain this won't do what you think. On the 1503, the port_c_pullups function accepts only a TRUE/FALSE value, so not giving a pull-up on C4, but on all the port C pins...

You need to start with code that works, to have any hope of porting it to another processor. Sad

When i compiled it with 16f676 with modifications.
Not get any error.
Also generate hex file.
But adc function not working.
That's my main problem.
_________________
sahu
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sat Jul 01, 2017 9:40 pm     Reply with quote

The ADC doesn't work because you set pin A4 to be an output pin.
The AN3 adc input is on pin A4. AN3 must be an input for the adc to work.

You made this mistake in your tris statement for PortA below:
Quote:
void init_peripheral(void)
{

set_tris_a([b]0x08);[/b] // RA3 TMR_relay reset
set_tris_c(0x10); // RC4 reset

You also set the Tris for pin A0 to be an output. So your other adc pin
AN0 also won't work.

My advice is, unless you understand exactly how to do it, don't bother
setting the Tris. Let the compiler do it automatically. Also, don't bother
using Fixed I/O statements. When you're a beginner, you will make
less mistakes if you let the compiler automatically handle setting the i/o
direction.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sun Jul 02, 2017 1:23 am     Reply with quote

As a comment, he is also ignoring the compiler warnings. If it ever worked on the 1503, it was a fluke:

">>> Warning 227 "maintest15.c" Line 2(9,15): Feature not supported ADC does not have that many bits 10<11"

For every compiler I have tried.

While warnings are sometimes things that may be ignored, when they are telling you that the chip can't do something, it becomes important to listen....
temtronic



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

View user's profile Send private message

PostPosted: Sun Jul 02, 2017 7:01 am     Reply with quote

this....
#rom 0x3FF = {0x3480}

has me 'concerned'

I'd like to know why you've stored 0x3480 in the middle of the EEPROM address space.

As for the 'read ADC 32 times not 40', the compiler will make a very,very FAST average( simple shift) as opposed to a long, time consuming /40.

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sun Jul 02, 2017 7:11 am     Reply with quote

He is not actually averaging. He takes the peak reading. Agree wholeheartedly for an average, but for the peak doesn't matter. Smile
temtronic



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

View user's profile Send private message

PostPosted: Sun Jul 02, 2017 7:18 am     Reply with quote

oops ! I'm so used to guys reading ADC a zillion times then averaging oddball numbers.....guess I should put the bifocals on when reading..sigh, getting old is 'fun'....
still curious about the value stuffed in the middle of ROM though...

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sun Jul 02, 2017 8:15 am     Reply with quote

Agreed. Very much so.
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