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

1824T39A
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
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

1824T39A
PostPosted: Mon Feb 04, 2019 9:34 am     Reply with quote

Hi all,

I'm working with the 16LF1824T39A, with the CCS 5.078, but I can't put it working with internal uart (tx buffer) PIN_C4 (PIN_B4 in the include file), it gives always "Error#96 Baud rate out of range" for an baud rate of 57600 @ 4Mhz internal clock. Is there any workaround to accomplish that?
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Mon Feb 04, 2019 9:54 am     Reply with quote

Work out what the baud rate generator is trying to do.
Calculate the baud rate generator divisor by dividing your clock frequency first by 16 then your intended baud rate. Now round off to the nearest whole number. How much error does the rounding off create? It needs to be of the order of a few percent.

Mike
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Mon Feb 04, 2019 10:36 am     Reply with quote

Hi Mike,

I need a standard baud rate, the reason for this is that I have an another micro (in this case is the 16F1825) that will receive the data by int_rda interrupt. That is the reason for trying to have a fast baud rate but standard (at least I need 19200bps...)
Digging both datasheets I can put different clock speeds (in this case 3.6864Mhz or 18.432 Mhz) with a much lower rate error..but using the normal functions of CCS
Code:
#use delay(internal=xxMhz)
is not possible...
Furthermore, I don´t know if in fact the
Code:
#use rs232(baud = 57600, parity=N, xmit=PIN_A0, rcv=PIN_A1, bits=8, errors, RESTART_WDT)
, is sending the data by software uart or by hardware uart...
PrinceNai



Joined: 31 Oct 2016
Posts: 482
Location: Montenegro

View user's profile Send private message

PostPosted: Mon Feb 04, 2019 12:01 pm     Reply with quote

It is a software uart, I believe. This chip has hardware uart on pins C4 and C5. You say that you need at least 19200 baud rate. With your setup even 38400 compiles fine. If you change clock speed to 8MHz, 5.600 works too.
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Mon Feb 04, 2019 12:25 pm     Reply with quote

the chip has an TX on PIN_A0 or in PIN_C4, according to device datasheet page 4:
"Pin function is selectable via the APFCON0 or APFCON1 registers."

So in this case I have done the following:
Code:
#byte   APFCON0  =                    getenv("SFR:APFCON0")


and in the init function I put the following

Code:

setup_uart(FALSE, PORT1);
APFCON0 |= 0x04;
setup_uart(TRUE, PORT1);
 


The problem is that I can't guarantee that even like the code shown above it is working by HW or SW ... if it is working by HW, I should have clock speed (4MHZ) to have the baud rate of 57600bps...
Ttelmah



Joined: 11 Mar 2010
Posts: 19594

View user's profile Send private message

PostPosted: Mon Feb 04, 2019 12:41 pm     Reply with quote

You can always ensure the hardware UART is used by using:

#use rs232(baud = 57600, parity=N, UART1, bits=8, errors)

This forces the code to be generated for hardware UART1.

Then simply select the pins with the APFCON register.
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 7:54 am     Reply with quote

Sorry for my delay, but I thought I had respond to this post, but for any reason, it was not published.

I had make as you have suggested (use the UART1) in the #use rs232 statment and it works just fine Smile thanks for that...
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 8:22 am     Reply with quote

now I have a slightly different problem that is making me nuts.. it should be simple but, somehow it misses something...

I have two analog inputs one for reading battery level (monitor) and the other for an normal ad input. So my code is as follows:

Code:
#device ADC=8

.....

Code:
#define normal_ad_entry         PIN_C3
#define Low_power_Reading         PIN_C2

#define ent_adc_normal_ad         sAN7
#define ent_adc_Low_power         sAN6
#define adc_ch_normal_ad                 7
#define adc_ch_Low_power         6


---- code for reading the ADs inputs: ---

Code:
setup_adc(ADC_OFF);
delay_ms(10);   
setup_adc_ports(NO_ANALOGS);
set_analog_pins(Low_power_Reading);
delay_ms(10);   
setup_vref(VREF_ON | VREF_ADC_1v024);
setup_adc_ports(ent_adc_Low_power, VSS_FVR);
delay_us(10);
setup_adc(ADC_CLOCK_INTERNAL);
delay_us(10);
set_adc_channel(adc_ch_Low_power); // also tried wit FVR_CHANNEL);
delay_us(10);
  //read_adc(ADC_START_ONLY);
  //while(!adc_done());
  //read_adc(ADC_READ_ONLY);
battery_adc_value_is = read_adc(); // and I don't have the correct values   I was expecting to have...


for the other input which works just fine is as follows:

Code:
setup_adc_ports(NO_ANALOGS);
set_analog_pins(normal_ad_entry);
delay_ms(10); 
setup_vref(VSS_VDD);
delay_us(10);
setup_adc_ports(ent_adc_normal_ad, VSS_VDD);
delay_us(10);
setup_adc(ADC_CLOCK_INTERNAL);
delay_us(10);
   
set_adc_channel(adc_ch_normal_ad);
delay_us(10); 

  //read_adc(ADC_START_ONLY);
  //while(!adc_done());
  //read_adc(ADC_READ_ONLY);
value_from_normal_ad_input = read_adc(); // and I don't have the correct values


and I just can't understand why...
Ttelmah



Joined: 11 Mar 2010
Posts: 19594

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 8:50 am     Reply with quote

There are several basic issues with what you are doing. First your ADC clock.

From the data sheet:

Quote:

When the device frequency is greater than 1 MHz, the FRC clock source is only recommended if the
conversion will be performed during Sleep.


Your clock is not recommended.

Then your use of the FVR.
It is not legal to use the 1.024V output from the FVR. The 2.048V output
is the lowest one legal for the ADC.
If you look at the selections in the data sheet:
Quote:

The ADPREF bits of the ADCON1 register provides
control of the positive voltage reference. The positive
voltage reference can be:
• VREF+ pin
• VDD
• FVR 2.028V
• FVR 4.096V (Not available on LF devices)


Note the lack of the 1.024V selection.
The reason is that this is less than the ADC is rated to run with. The
minimum Vref the ADC is rated to use is 1.8V.

Now you don't say what the voltage you are trying to measure actually
'is'. However it must not be greater than the Vref.

Change your clock to use FOSC/8 (the recommended setting for 4MHz),
and select the 2.048 Vref, and you may well find things start to work.
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 9:18 am     Reply with quote

I was trying to use the FVR module

14.0 FIXED VOLTAGE REFERENCE (FVR)The Fixed Voltage Reference (FVR),
Quote:
is a stable voltage reference, independent of VDD, with 1.024V, 2.048V or4.096V selectable output levels. The output of the FVR can be configured to supply a reference voltage to the following:
• ADC input channel
• ADC positive reference
• Comparator positive input
• Digital-to-Analog Converter (DAC)

The FVR can be enabled by setting the FVREN bit ofthe FVRCON register


About the clock I had already use tested with the Fosc/8 and Fosc/4 with no luck, that was why I had changed to the internal_adc_clock..

About the voltage, I'm measuring, the micro is powered my and CR2032 battery and I have an external circuit that (from my calculations) could be from 0 to 6V (maximum). In this case as I have only 3.3V, I have to make the corresponding calculations, but in fact the problem was the readings that were not correct.. I will test it again...in a short time I will let you know
temtronic



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

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 9:32 am     Reply with quote

According to the PIC's datasheet, ADC electrical section...

AD07 V AIN Full-Scale Range VSS — VREF V


Since you're using FVR of 2.028 as the VREF, the INPUT to the ADC cannot be greater than 2.028
So the way I read the spec, you can't read the 6 volt input !! It's NOT allowed.

To read a voltage greater than VREF, you can use a voltage divider using 2 , 1% resistors, say 2K and 1K, that will make the 6 volt source look like 2 volts. For accurate measurements, run a few 'calibrations tests' to get the correct 'multiplier' when displaying the '6v reading'.

Jay
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 9:34 am     Reply with quote

welll... with your suggestions.. now is working (the value that I half of the one I was expecting as it supposed)... so my datasheet reading was not as accurate as it should...thanks Ttelmah
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 9:36 am     Reply with quote

temtronic, I don't read the 6V... I'm just saying that my external circuit can(or could) handle the 6V and treat it as 3.0V in the micro pin input.
Ttelmah



Joined: 11 Mar 2010
Posts: 19594

View user's profile Send private message

PostPosted: Sat Feb 23, 2019 11:09 am     Reply with quote

3v, is still above the Vref. So you need to think again, and redesign
the divider to ensure the voltage can never go above your Vref.
ralph79



Joined: 29 Aug 2007
Posts: 87

View user's profile Send private message

PostPosted: Mon Feb 25, 2019 6:15 am     Reply with quote

below I send my ancient circuit:
VCC is the battery voltage, is the same voltage for the micro power supply.

[img] https://imgur.com/a/WfwcVkZ [/img]

The ACT_L_POWER is an dedicated output pin (active low), so my idea was, when I want to read the battery voltage, make an active low to the ACT_L_POWER pin, and make the ADC reading based on the voltage reference. I would like to use the 1.024V because the micro can be operating at 1.8V...if that isn't possible I will have to use an external voltage reference...
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