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

PCD C Compiler v5.093 - Use invalid cpu clock & fuses?
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
ArthurDavidov



Joined: 03 Mar 2021
Posts: 9

View user's profile Send private message

PCD C Compiler v5.093 - Use invalid cpu clock & fuses?
PostPosted: Wed Mar 03, 2021 9:34 am     Reply with quote

Hi all,
I am using pic24ep512gp806, CCS PCD C Compiler, Version 5.093.

1.
What is happening in case I set #use delay() with invalid value CPU clock (according to datasheet)?

#use delay(oscillator=25M, clock=130M)
Is this definition is safe and can handle with an invalid CPU value?


2.
What is happening in case I use with not supported by PIC24 #fuse?
Can it harm something or just ignored?


The compilation on both case is successful.

Thanks.
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Wed Mar 03, 2021 10:32 am     Reply with quote

Depends what the fuse is. It may be ignored, or it may result in setups
the chip cannot perform. It is possible to set the fuses in some cases to
values the data sheet marks as 'not supported'. What will happen here
is completely undocumented.
The clock may work. Chips can often go past their rated speeds, but will
possibly be unreliable and may well result in overheating.
At the end of the day, it is up to you to set these values correctly.
This is why we often suggest building your own set of default 'known good'
settings for a particular chip that you then use.
temtronic



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

View user's profile Send private message

PostPosted: Wed Mar 03, 2021 11:53 am     Reply with quote

I'd have to check but I 'thought' the top clock for a PIC24 was 120MHz, even then you have to be SURE the PIC doesn't overheat ( <85*C ?? )

In any event you should NOT 'overclock' a PIC. While the one you're testing might be 'fine', there's NO way it'll perform 100% in the 'real world'.

I don't know if the compiler is supersmart and NOT allow clocks over design specs, you'll have to code, compile and look at the HEX file to see.
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Wed Mar 03, 2021 12:12 pm     Reply with quote

That is the point. He is asking what will happen if he specifies an overclocked
setting....
temtronic



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

View user's profile Send private message

PostPosted: Wed Mar 03, 2021 2:51 pm     Reply with quote

If the compiler allows and sets it to 'overclock', it might run ok, until it overheats and either stops working or dies.....
Normally you have to super cool a CPU to get it to run reilably BUT 'other stuff' can happen...... all DIO on I/O pins runs faster, could be 'out of spec' for whatever they're attached to.That may cause corrupt data or damage to the peripheral. Internals such as I2C,SPI, UART may be OK,providing they can be set for the correct speed.
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 1:11 am     Reply with quote

Generally, the compiler will allow an overclock to be selected, but if it goes
beyond the 'possible' clocks for things like the intermediate stages in the
PLL, this won;t be allowed.
Some overclocking may be 'reasonable'. Years ago, I had a PIC, that for
certain frequency 'reasons', needed to be clocked from a frequency that
was about 4% outside the maximum specified. I contacted Microchip,
and they stated that this was completely OK, provided we stayed inside
the 'I' temperature rating range. However the margins on chips like the
DsPIC's are very much lower than they were then....
The compiler also has to recognise that sometimes Microchip launch
later variants with a higher maximum rated frequency. This has happened
in the past with a couple of the PIC18's. So if the compiler blocks the
selection of an 'above specification' frequency, it then results in a new
compiler version being needed for a variant with the same type number.
Hence in general some overclocking is often allowed.
As Jay says, heat and peripheral performance are the big problems,
especially when you start to get up to frequencies like 100MHz+.....
You get silly things like the I2C, SPI, UART, ADC etc., giving issues,
when you push the frequencies.
ArthurDavidov



Joined: 03 Mar 2021
Posts: 9

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 1:30 am     Reply with quote

Thanks for your response and time.

1.
The question about the invalid CPU clock is not only above MAX, it can be also lower than MAX but doesn't meet the limits and constraints in the PLL diagram (from datasheet).

For example, 49Mhz doesn't fit due to PLL questions but 50Mhz is matching all limits in diagram. How does the CCS compiler react in this case? How he calculate the prescalers? Is he round? ceil?
The compilation is successful without warnings.


2. about the fuses in case I declare:
#fuses NOJTAG, NOWDT, NOIOL1WAY, NOWRT, NOPROTECT

But supported fuses according to my '24ep512GP806.h' are:
JTAG, WDT, IOL1WAY, WRT, PROTECT

So in this case, declared fuses will be just ignored? Or can lead to something unstable?

Thanks a lot for your responses.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 1:46 am     Reply with quote

ArthurDavidov wrote:

2. about the fuses in case I declare:
#fuses NOJTAG, NOWDT, NOIOL1WAY, NOWRT, NOPROTECT

But supported fuses according to my '24ep512GP806.h' are:
JTAG, WDT, IOL1WAY, WRT, PROTECT

So in this case, declared fuses will be just ignored? Or can lead to something unstable?

The fuses shown in bold above are all supported. They can be used
with no problems.

If you put in a nonsense fuse like this:
Code:
#fuses ABCXYZ
Then the compiler will give you an error:
Quote:
Unknown keyword in #FUSES "ABCXYZ"
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 2:06 am     Reply with quote

Understand that 'NOJTAG', simply means 'Turn off the JTAG fuse'. It is not
a new fuse.....
ArthurDavidov



Joined: 03 Mar 2021
Posts: 9

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 2:39 am     Reply with quote

Ttelmah
Thanks, I know the meaning, so I can use with this even if not appear in the list of supported fusses from <24ep512GP806.h>:

#nolist
//////// Program memory: 175104x24 Data RAM: 53248 Stack: 31
//////// I/O: 53 Analog Pins: 24
//////// Fuses: WRT,PROTECT,NOGSSK,GSSK,FRC,FRC_PLL,PR,PR_PLL,SOSC,LPRC
//////// Fuses: FRC_DIV_BY_16,FRC_PS,IESO,EC,XT,HS,NOPR,OSCIO,IOL1WAY,CKSFSM
//////// Fuses: CKSNOFSM,NOCKSNOFSM,WPOSTS1,WPOSTS2,WPOSTS3,WPOSTS4,WPOSTS5
//////// Fuses: WPOSTS6,WPOSTS7,WPOSTS8,WPOSTS9,WPOSTS10,WPOSTS11,WPOSTS12
//////// Fuses: WPOSTS13,WPOSTS14,WPOSTS15,WPOSTS16,WPRES32,WPRES128,PLLWAIT
//////// Fuses: WINDIS,WDT,NOPUT,PUT2,PUT4,PUT8,PUT16,PUT32,PUT64,PUT128
//////// Fuses: BROWNOUT,ALTI2C1,ICSP3,ICSP2,ICSP1,RESET_AUX,RESET_PRIMARY
//////// Fuses: JTAG,DEBUG,AWRT,APROTECT,NOAPLK,APLK
////////


What about using invalid values of CPU clock (doesn't meet the PLL requirements due to datasheet calculations)?
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 3:20 am     Reply with quote

Yes. The list is only done for convenience. Unfortunately things are
sometimes missed. The place to actually look is the device editor (assuming
you have the IDE), and in the top right of the window there is a list of
the fuses, with [NO]JTAG shown. For the 'JTAG' fuse with a supported
'NO' option.
I've moaned before to CCS, that they really ought to create a program that
builds the list from the device database, so that the two can't differ, but
it looks as if they are still 'hand creating' this....
The .LST file from a compile is also much more informative:
Code:

   Word  8L: 00D7   ICSP1 RESET_PRIMARY NOJTAG NODEBUG
          H: 0000 
   Word  9L: 0003   NOAWRT NOAPROTECT NOAPLK
          H: 0000 


As you can see, NOJTAG being merrily shown (this is for your chip).
ArthurDavidov



Joined: 03 Mar 2021
Posts: 9

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 3:29 am     Reply with quote

Thanks for the very informative explanation.

Could you also help with CPU clock issue?
Can I see the disassembly of #use delay() to detect the prescalers values?

ArthurDavidov wrote:
Thanks for your response and time.

1.
The question about the invalid CPU clock is not only above MAX, it can be also lower than MAX but doesn't meet the limits and constraints in the PLL diagram (from datasheet).

For example, 49Mhz doesn't fit due to PLL questions but 50Mhz is matching all limits in PLL Block Diagram. How does the CCS compiler react in this case? How he calculate the prescalers? Is he round? ceil?
The compilation is successful without warnings.
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Thu Mar 04, 2021 5:24 am     Reply with quote

Yes.

Open the device include file.
Rem out the line #nolist, so it becomes
//#nolist
Edit it in the IDE, and when you go to save it, tell the compiler to save it
as a copy with your project.
Then in your project, change the line:

#include <Processor.h>

to:

#include "Processor.h"

Where 'Processor' is the processor number you are using. Using the inverted
commas makes the compiler load the version with your project instead of
the 'master' copy.

Then re-compile.

You will find at the start of the main all the compiler code for this is now
shown. It'll be a section like:
Code:

0DC3C:  BCLR.B  OSCCON.IOLOCK
0DC3E:  MOV     #1800,W0
0DC40:  MOV     W0,RPINR0
0DC42:  MOV     #25,W0
0DC44:  MOV     W0,RPINR18
0DC46:  MOV     #38,W0
0DC48:  MOV     W0,RPINR19
0DC4A:  MOV     #32,W0
0DC4C:  MOV     W0,RPINR27
0DC4E:  MOV     #2D,W0
0DC50:  MOV     W0,RPINR28
0DC52:  MOV     #11,W0
0DC54:  MOV     W0,RPOR1
0DC56:  MOV     #1,W0
0DC58:  MOV     W0,RPOR2
0DC5A:  MOV     #1D00,W0
0DC5C:  MOV     W0,RPOR4
0DC5E:  MOV     #1B10,W0
0DC60:  MOV     W0,RPOR5
0DC62:  MOV     #300,W0
0DC64:  MOV     W0,RPOR6
0DC66:  DISI    #6
0DC68:  MOV     #742,W1
0DC6A:  MOV     #46,W2
0DC6C:  MOV     #57,W3
0DC6E:  MOV.B   W2L,[W1]
0DC70:  MOV.B   W3L,[W1]
0DC72:  BSET.B  OSCCON.IOLOCK
0DC74:  BSET.B  CORCON.SFA
ArthurDavidov



Joined: 03 Mar 2021
Posts: 9

View user's profile Send private message

PostPosted: Mon Mar 08, 2021 8:50 am     Reply with quote

Thank you for your guide. I did it and the difference is only in line 268:

.................... #use delay(oscillator=25M, clock=100M)
*
00262: CP0 W0
00264: BTSC.B 42.1
00266: BRA 27C
00268: REPEAT #34B
0026A: NOP
0026C: REPEAT #3FFE
0026E: NOP
00270: REPEAT #3FFE
00272: NOP
00274: REPEAT #3FFE
00276: NOP
00278: DEC W0,W0
0027A: BRA NZ,268
0027C: RETURN

I tried with invalid CPU clock (according to PLL diagram):
.................... #use delay(oscillator=25M, clock=130M)
*
00262: CP0 W0
00264: BTSC.B 42.1
00266: BRA 27C
00268: REPEAT #3DE3
0026A: NOP
0026C: REPEAT #3FFE
0026E: NOP
00270: REPEAT #3FFE
00272: NOP
00274: REPEAT #3FFE
00276: NOP
00278: DEC W0,W0
0027A: BRA NZ,268
0027C: RETURN

Is there any way to find the PLL prescaler, PLL postscaler, PLL divisor to understand the result of using with invalid CPU CLock?
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Mon Mar 08, 2021 8:57 am     Reply with quote

What you are posting is not the clock setup. That is a delay, which changes
because the clock rate changes. The code for delays is before the clock
settings. The clock setup code is at the start of the main.
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