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

PCW compiler typedef'ed array issue

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



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PCW compiler typedef'ed array issue
PostPosted: Mon Feb 07, 2011 9:40 am     Reply with quote

I'm a experienced professional developer working on PCWH 4.017 for a medium term contract. The company currently doesn't have support for the IDE or compiler.

I want to know if this is a known problem. If so, does anyone know if it has been fixed. In other words is it worth my while trying to make a case for re-establishing support?

The problem is a compiler issue relating to typedef and arrays. The generated assembler code for arrays of ints and int32s is different when directly declared from that when declared through an equivalent typedef. If declared with a typedef the compiler generates code that treats each int or int32 as if they were int16, however it correctly addresses the ints or int32s! Note that when single variables are used instead of arrays the code is good.

Here is my test code. If the declare, which defines the type to test, is int8 or int32 then the problem occurs, however int16 is OK.

I am targeting the PIC18F8585 at 10MHz.

Code:
#include <18F8585.h>
#device ICD=TRUE
#device adc=8

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES WDT128                   //Watch Dog Timer uses 1:128 Postscale
#FUSES EC_IO                    //External clock
#FUSES NOPROTECT                //Code not protected from reading
#FUSES NOOSCSEN                 //Oscillator switching is disabled, main oscillator is source
#FUSES NOBROWNOUT               //No brownout reset
#FUSES BORV20                   //Brownout reset at 2.0V
#FUSES PUT                      //Power Up Timer
#FUSES NOCPD                    //No EE protection
#FUSES STVREN                   //Stack full/underflow will cause reset
#FUSES NODEBUG                  //No Debug mode for ICD
#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES NOWRT                    //Program memory not write protected
#FUSES NOWRTD                   //Data EEPROM not write protected
#FUSES NOWRTC                   //configuration not registers write protected
#FUSES NOWRTB                   //Boot block not write protected
#FUSES NOEBTR                   //Memory not protected from table reads
#FUSES NOEBTRB                  //Boot block not protected from table reads
#FUSES NOCPB                    //No Boot Block code protection
#FUSES MCLR                     //Master Clear pin enabled
#FUSES MCU                      //Microcontroller Mode
#FUSES NOWAIT                   //Wait selections unavailable for Table Reads or Table Writes
#FUSES ECCPE                    //Enhanced CCP PWM outpts multiplexed with RE6 thorugh RE3

#use delay(clock=10000000)


void main()
{

   setup_adc_ports(NO_ANALOGS|VSS_VDD);
   setup_adc(ADC_OFF);
   setup_psp(PSP_DISABLED);
   setup_spi(SPI_SS_DISABLED);
   setup_wdt(WDT_OFF);
   setup_timer_0(RTCC_INTERNAL);
   setup_timer_1(T1_DISABLED);
   setup_timer_2(T2_DISABLED,0,1);
   setup_comparator(NC_NC_NC_NC);
   setup_vref(FALSE);
//Setup_Oscillator parameter not selected from Intr Oscillator Config tab

#define base int8 // or int16, or int32
   typedef base typedef_type;
   
   base int_byte;
   
   typedef_type typedef_byte;
   
   typedef base typedef_array_type[2];
   
   // Declare two 4 byte arrays. One directly...
   base int_array[2];
   // ...one with an equivalent typedef.
   typedef_array_type typedef_array;
   
   int_array[0] = 0x01;
   int_array[1] = 0x02;

   
   // This should generate similar code to the above, with different addresses of course.
   typedef_array[0] = 0x10;
   typedef_array[1] = 0x20;

   
   // Code for the typedef'ed array includes a spurious CLRF clearing a non-existant MS byte!
   
   // Code for single variables is fine.
    int_byte = 0x01;
    typedef_byte = 0x02;
}


this is an extract from the lst file showing the resulting assembler:

Code:
.................... #define base int8 // or int16, or int32
....................    typedef base typedef_type;
....................     
....................    base int_byte;
....................     
....................    typedef_type typedef_byte;
....................     
....................    typedef base typedef_array_type[2];
....................     
....................    // Declare two 4 byte arrays. One directly...
....................    base int_array[2];
....................    // ...one with an equivalent typedef.
....................    typedef_array_type typedef_array; 
....................     
....................    int_array[0] = 0x01;
005C:  MOVLW  01
005E:  MOVWF  07
....................    int_array[1] = 0x02;
0060:  MOVLW  02
0062:  MOVWF  08
.................... 
....................     
....................    // This should generate similar code to the above, with different addresses of course.
....................    typedef_array[0] = 0x10;
0064:  CLRF   0A
0066:  MOVLW  10
0068:  MOVWF  09
....................    typedef_array[1] = 0x20;
006A:  CLRF   0B
006C:  MOVLW  20
006E:  MOVWF  0A
.................... 
....................     
....................    // Code for the typedef'ed array includes a spurious CLRF clearing a non-existant MS byte!
....................     
....................    // Code for single variables is fine.
....................     int_byte = 0x01;
0070:  MOVLW  01
0072:  MOVWF  05
....................     typedef_byte = 0x02;
0074:  MOVLW  02
0076:  MOVWF  06
.................... }
0078:  BRA    0078


As I don't have access to CCS support there's no chance of me raising this issue with them. All I really need to know is whether this is a known problem and if it has been fixed yet.

If you're still reading this then thanks for sticking with it!

RF_Developer
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Feb 07, 2011 1:00 pm     Reply with quote

I copied and pasted your code into an MPLAB project and compiled it with
PCH vs. 4.118. Here's the .LST file:
Code:

....................    typedef base typedef_array_type[2]; 
....................     
....................    // Declare two 4 byte arrays. One directly... 
....................    base int_array[2]; 
....................    // ...one with an equivalent typedef. 
....................    typedef_array_type typedef_array; 
....................     
....................    int_array[0] = 0x01; 
005C:  MOVLW  01
005E:  MOVWF  07
....................    int_array[1] = 0x02; 
0060:  MOVLW  02
0062:  MOVWF  08
.................... 
....................     
....................    // This should generate similar code to the above, with different addresses of course. 
....................    typedef_array[0] = 0x10; 
0064:  MOVLW  10
0066:  MOVWF  09
....................    typedef_array[1] = 0x20; 
0068:  MOVLW  20
006A:  MOVWF  0A
.................... 
....................     
....................    // Code for the typedef'ed array includes a spurious CLRF clearing a non-existant MS byte! 
....................     
....................    // Code for single variables is fine. 
....................     int_byte = 0x01; 
006C:  MOVLW  01
006E:  MOVWF  05
....................     typedef_byte = 0x02; 
0070:  MOVLW  02
0072:  MOVWF  06
.................... } 
.................... 
Ttelmah



Joined: 11 Mar 2010
Posts: 19499

View user's profile Send private message

PostPosted: Mon Feb 07, 2011 3:33 pm     Reply with quote

And, the critical thing is the PCWH version here. Generally, the early V4 compilers, _were not useable_. The 'line' for a compiler that began to work reasonably well, was around the late 4.06x version. 4.017, I wouldn't even trust to compile a basic 'hello world' type program, let alone deal with typedef and an array. I keep the compilers I use for projects, and there is a large 'gap' in the sequence, going 3.249, then 4.070....
Just as a test, I stuck the typedefs into 4.099, and this too handled them OK.
Forget 4.017.
For many months, there was a sticky thread at the head of the forum, about the progress with the compilers. This was only removed, when they began to work.

Best Wishes
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PostPosted: Tue Feb 08, 2011 2:52 am     Reply with quote

Thanks, that pretty much answers my questions, and raises possibly nasty issues.

For a long while yesterday I thought I was going out with the fairies... before finding this problem.

I've worked round it by simply removing the affected typedefs. Not so tidy, but at least it works!

The long term implications are more worrying. Yes, I can perhaps persuade the company to upgrade, but I also have to persuade them that they have to use a commercially available tool that for fairly long periods has been known to have had significant functional shortcomings (i.e. is potentially unusable cr&p)... but then what software tool doesn't in one way or another?

By the way, does anyone else find the debugger's - possible legacy hangover - habit of displaying pointers as 8 bit only rather annoying, and massively timewasting?

Oh yes, and our two Mach X programmer/debuggers are only borderline usable as their comms locks up in some unknown way; commonly in the verify pass after loading ICD code but also while actively debugging. The CCS IDE's handling of these errors is very frustrating, necessitating lots of waiting (generally accompanied by groans, sighs, cusses and copious cups of tea) and killing of the IDE app and other similar drastic measures. I typically lose two or more hours to this every day. So much so that I've had to insist that we change to another ICD unit, probably Microchip's own MPLAB ICD3 (we apparently use the ICD2 for our small-scale production programming).

Anyway, thanks for the replies.

RF_Developer
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