- bug fix in VASY VHDL compiler

(while choosing a default label for unlabelled process or loops)
This commit is contained in:
Ludovic Jacomme 2003-10-27 18:14:32 +00:00
parent a4bf03dd8f
commit e9124e1441
2 changed files with 14 additions and 6 deletions

View File

@ -336,6 +336,8 @@ design_file
VBL_MODNAM = namealloc( "undefined" ); VBL_MODNAM = namealloc( "undefined" );
VBL_PROCNAM = (char *)0; VBL_PROCNAM = (char *)0;
VBL_PROCNUM = 0;
VBL_LOOPNUM = 0;
VBL_GNRNAM = (char *)0; VBL_GNRNAM = (char *)0;
VBL_FUNCNAM = (char *)0; VBL_FUNCNAM = (char *)0;
VBL_COMPNAM = (char *)0; VBL_COMPNAM = (char *)0;
@ -4786,7 +4788,8 @@ unlabeled_conditional_signal_assignment
vbh_addvbwas( SensList, NULL, 0, NULL, VBL_LINNUM ) ); vbh_addvbwas( SensList, NULL, 0, NULL, VBL_LINNUM ) );
Inst = reversetype( Inst ); Inst = reversetype( Inst );
sprintf( Buffer, "p%ld", VBL_LINNUM ); VBL_PROCNUM++;
sprintf( Buffer, "p%ld_%ld", VBL_LINNUM, VBL_PROCNUM );
VBL_PROCNAM = namealloc( Buffer ); VBL_PROCNAM = namealloc( Buffer );
VBL_BEPCS = vbh_addvbpcs( VBL_BEPCS, VBL_PROCNAM, NULL, Inst, VBL_LINNUM ); VBL_BEPCS = vbh_addvbpcs( VBL_BEPCS, VBL_PROCNAM, NULL, Inst, VBL_LINNUM );
VBL_BEPCS->TYPE = ProcessType; VBL_BEPCS->TYPE = ProcessType;
@ -5049,7 +5052,8 @@ unlabeled_selected_signal_assignment
Inst->NEXT = addptype( (ptype_list *)0, VBH_BEWAS, Inst->NEXT = addptype( (ptype_list *)0, VBH_BEWAS,
vbh_addvbwas( SensList, NULL, 0, NULL, VBL_LINNUM ) ); vbh_addvbwas( SensList, NULL, 0, NULL, VBL_LINNUM ) );
sprintf( Buffer, "p%ld", VBL_LINNUM ); VBL_PROCNUM++;
sprintf( Buffer, "p%ld_%ld", VBL_LINNUM, VBL_PROCNUM );
VBL_PROCNAM = namealloc( Buffer ); VBL_PROCNAM = namealloc( Buffer );
VBL_BEPCS = vbh_addvbpcs( VBL_BEPCS, VBL_PROCNAM, NULL, Inst, VBL_LINNUM ); VBL_BEPCS = vbh_addvbpcs( VBL_BEPCS, VBL_PROCNAM, NULL, Inst, VBL_LINNUM );
VBL_BEPCS->TYPE = ProcessType; VBL_BEPCS->TYPE = ProcessType;
@ -5097,8 +5101,9 @@ process_statement
} }
unlabeled_process_statement unlabeled_process_statement
| { | {
char buffer[ 20 ]; char buffer[ 128 ];
sprintf( buffer, "p%ld", VBL_LINNUM ); VBL_PROCNUM++;
sprintf( buffer, "p%ld_%ld", VBL_LINNUM, VBL_PROCNUM );
VBL_PROCNAM = namealloc( buffer ); VBL_PROCNAM = namealloc( buffer );
} }
unlabeled_process_statement unlabeled_process_statement
@ -5300,9 +5305,10 @@ loop_statement
unlabeled_loop_statement unlabeled_loop_statement
| |
{ {
char buffer[ 20 ]; char buffer[ 128 ];
sprintf( buffer, "loop_%ld", VBL_LINNUM ); VBL_LOOPNUM++;
sprintf( buffer, "loop_%ld_%ld", VBL_LINNUM, VBL_LOOPNUM );
VBL_LOOPLBLLST = addchain ( VBL_LOOPLBLLST, namealloc( buffer ) ); VBL_LOOPLBLLST = addchain ( VBL_LOOPLBLLST, namealloc( buffer ) );
} }
unlabeled_loop_statement unlabeled_loop_statement

View File

@ -62,6 +62,8 @@ pNode VBL_BDDPNT;
char *VBL_MODNAM; /* curnennt model name */ char *VBL_MODNAM; /* curnennt model name */
char *VBL_PROCNAM; /* current process name */ char *VBL_PROCNAM; /* current process name */
char *VBL_FUNCNAM; /* current function/procedure name */ char *VBL_FUNCNAM; /* current function/procedure name */
long VBL_PROCNUM;
long VBL_LOOPNUM;
char *VBL_COMPNAM; char *VBL_COMPNAM;
char *VBL_SAVCOMPNAM; char *VBL_SAVCOMPNAM;
char *VBL_GNRNAM; /* current generate name */ char *VBL_GNRNAM; /* current generate name */