2002-11-21 Andrew Cagney <ac131313@redhat.com>
* Makefile.in: Update copyright. IGEN contributed to the FSF.
* filter.c, filter.h, filter_host.c, filter_host.h: Ditto.
* gen-engine.c, gen-engine.h, gen-icache.c, gen-icache.h: Ditto.
* gen-idecode.c, gen-idecode.h, gen-itable.c: Ditto.
* gen-itable.h, gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h, gen.c: Ditto.
* gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:09:40 +08:00
/* The IGEN simulator generator for GDB, the GNU Debugger.
2009-01-14 18:53:10 +08:00
Copyright 2002 , 2007 , 2008 , 2009 Free Software Foundation , Inc .
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* Makefile.in: Update copyright. IGEN contributed to the FSF.
* filter.c, filter.h, filter_host.c, filter_host.h: Ditto.
* gen-engine.c, gen-engine.h, gen-icache.c, gen-icache.h: Ditto.
* gen-idecode.c, gen-idecode.h, gen-itable.c: Ditto.
* gen-itable.h, gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h, gen.c: Ditto.
* gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:09:40 +08:00
Contributed by Andrew Cagney .
This file is part of GDB .
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-08-24 22:30:15 +08:00
the Free Software Foundation ; either version 3 of the License , or
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* Makefile.in: Update copyright. IGEN contributed to the FSF.
* filter.c, filter.h, filter_host.c, filter_host.h: Ditto.
* gen-engine.c, gen-engine.h, gen-icache.c, gen-icache.h: Ditto.
* gen-idecode.c, gen-idecode.h, gen-itable.c: Ditto.
* gen-itable.h, gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h, gen.c: Ditto.
* gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:09:40 +08:00
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
2007-08-24 22:30:15 +08:00
along with this program . If not , see < http : //www.gnu.org/licenses/>. */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* Makefile.in: Update copyright. IGEN contributed to the FSF.
* filter.c, filter.h, filter_host.c, filter_host.h: Ditto.
* gen-engine.c, gen-engine.h, gen-icache.c, gen-icache.h: Ditto.
* gen-idecode.c, gen-idecode.h, gen-itable.c: Ditto.
* gen-itable.h, gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h, gen.c: Ditto.
* gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:09:40 +08:00
1999-04-16 09:35:26 +08:00
# include "misc.h"
# include "lf.h"
# include "table.h"
# include "filter.h"
# include "igen.h"
# include "ld-insn.h"
# include "ld-decode.h"
# include "gen.h"
# include "gen-idecode.h"
# include "gen-icache.h"
# include "gen-semantics.h"
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_print_opcodes ( lf * file , gen_entry * table )
1999-04-16 09:35:26 +08:00
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( table ! = NULL )
1999-04-16 09:35:26 +08:00
{
while ( 1 )
{
ASSERT ( table - > opcode ! = NULL ) ;
lf_printf ( file , " _%d_%d " ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
table - > opcode - > first , table - > opcode - > last ) ;
if ( table - > parent = = NULL )
break ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " __%d " , table - > opcode_nr ) ;
table = table - > parent ;
}
}
}
static void
print_idecode_ifetch ( lf * file ,
int previous_nr_prefetched_words ,
int current_nr_prefetched_words )
{
int word_nr ;
for ( word_nr = previous_nr_prefetched_words ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
word_nr < current_nr_prefetched_words ; word_nr + + )
1999-04-16 09:35:26 +08:00
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file ,
" instruction_word instruction_%d = IMEM%d_IMMED (cia, %d); \n " ,
1999-04-16 09:35:26 +08:00
word_nr , options . insn_bit_size , word_nr ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
}
}
/****************************************************************/
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_print_table_name ( lf * file , gen_entry * table )
1999-04-16 09:35:26 +08:00
{
lf_printf ( file , " idecode_table " ) ;
lf_print_opcodes ( file , table ) ;
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_table ( lf * file , gen_entry * entry , const char * result )
1999-04-16 09:35:26 +08:00
{
lf_printf ( file , " /* prime the search */ \n " ) ;
lf_printf ( file , " idecode_table_entry *table = " ) ;
lf_print_table_name ( file , entry ) ;
lf_printf ( file , " ; \n " ) ;
lf_printf ( file , " int opcode = EXTRACTED%d (instruction, %d, %d); \n " ,
options . insn_bit_size ,
i2target ( options . hi_bit_nr , entry - > opcode - > first ) ,
i2target ( options . hi_bit_nr , entry - > opcode - > last ) ) ;
lf_printf ( file , " idecode_table_entry *table_entry = table + opcode; \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
lf_printf ( file , " \n " ) ;
lf_printf ( file , " /* iterate until a leaf */ \n " ) ;
lf_printf ( file , " while (1) { \n " ) ;
lf_printf ( file , " signed shift = table_entry->shift; \n " ) ;
lf_printf ( file , " if (shift == function_entry) break; \n " ) ;
lf_printf ( file , " if (shift >= 0) { \n " ) ;
lf_printf ( file , " table = ((idecode_table_entry*) \n " ) ;
lf_printf ( file , " table_entry->function_or_table); \n " ) ;
lf_printf ( file , " opcode = ((instruction & table_entry->mask) \n " ) ;
lf_printf ( file , " >> shift); \n " ) ;
lf_printf ( file , " table_entry = table + opcode; \n " ) ;
lf_printf ( file , " } \n " ) ;
lf_printf ( file , " else { \n " ) ;
lf_printf ( file , " /* must be a boolean */ \n " ) ;
lf_printf ( file , " ASSERT(table_entry->shift == boolean_entry); \n " ) ;
lf_printf ( file , " opcode = ((instruction & table_entry->mask) \n " ) ;
lf_printf ( file , " != table_entry->value); \n " ) ;
lf_printf ( file , " table = ((idecode_table_entry*) \n " ) ;
lf_printf ( file , " table_entry->function_or_table); \n " ) ;
lf_printf ( file , " table_entry = table + opcode; \n " ) ;
lf_printf ( file , " } \n " ) ;
lf_printf ( file , " } \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
lf_printf ( file , " \n " ) ;
lf_printf ( file , " /* call the leaf code */ \n " ) ;
if ( options . gen . code = = generate_jumps )
{
lf_printf ( file , " goto *table_entry->function_or_table; \n " ) ;
}
else
{
lf_printf ( file , " %s " , result ) ;
if ( options . gen . icache )
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file ,
" (((idecode_icache*)table_entry->function_or_table) \n " ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " ( " ) ;
print_icache_function_actual ( file , 1 ) ;
lf_printf ( file , " )); \n " ) ;
}
else
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file ,
" ((idecode_semantic*)table_entry->function_or_table) \n " ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " ( " ) ;
print_semantic_function_actual ( file , 1 ) ;
lf_printf ( file , " ); \n " ) ;
}
}
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_table_start ( lf * file , gen_entry * table , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
ASSERT ( depth = = 0 ) ;
/* start of the table */
if ( table - > opcode_rule - > gen = = array_gen )
{
lf_printf ( file , " \n " ) ;
lf_printf ( file , " static idecode_table_entry " ) ;
lf_print_table_name ( file , table ) ;
lf_printf ( file , " [] = { \n " ) ;
}
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_table_leaf ( lf * file , gen_entry * entry , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
gen_entry * master_entry ;
ASSERT ( entry - > parent ! = NULL ) ;
ASSERT ( depth = = 0 ) ;
if ( entry - > combined_parent = = NULL )
master_entry = entry ;
else
master_entry = entry - > combined_parent ;
/* add an entry to the table */
if ( entry - > parent - > opcode_rule - > gen = = array_gen )
{
lf_printf ( file , " /*%d*/ { " , entry - > opcode_nr ) ;
if ( entry - > opcode = = NULL )
{
ASSERT ( entry - > nr_insns = = 1 ) ;
/* table leaf entry */
lf_printf ( file , " function_entry, 0, 0, " ) ;
if ( options . gen . code = = generate_jumps )
{
lf_printf ( file , " && " ) ;
}
print_function_name ( file ,
entry - > insns - > insn - > name ,
entry - > insns - > insn - > format_name ,
NULL ,
master_entry - > expanded_bits ,
( options . gen . icache
? function_name_prefix_icache
: function_name_prefix_semantics ) ) ;
}
else if ( entry - > opcode_rule - > gen = = switch_gen
| | entry - > opcode_rule - > gen = = goto_switch_gen
| | entry - > opcode_rule - > gen = = padded_switch_gen )
{
/* table calling switch statement */
lf_printf ( file , " function_entry, 0, 0, " ) ;
if ( options . gen . code = = generate_jumps )
{
lf_printf ( file , " && " ) ;
}
lf_print_table_name ( file , entry ) ;
}
else if ( entry - > opcode - > is_boolean )
{
/* table `calling' boolean table */
lf_printf ( file , " boolean_entry, " ) ;
lf_printf ( file , " MASK32(%d, %d), " ,
i2target ( options . hi_bit_nr , entry - > opcode - > first ) ,
i2target ( options . hi_bit_nr , entry - > opcode - > last ) ) ;
lf_printf ( file , " INSERTED32(%d, %d, %d), " ,
entry - > opcode - > boolean_constant ,
i2target ( options . hi_bit_nr , entry - > opcode - > first ) ,
i2target ( options . hi_bit_nr , entry - > opcode - > last ) ) ;
lf_print_table_name ( file , entry ) ;
}
else
{
/* table `calling' another table */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file , " %d, " ,
options . insn_bit_size - entry - > opcode - > last - 1 ) ;
lf_printf ( file , " MASK%d(%d,%d), " , options . insn_bit_size ,
1999-04-16 09:35:26 +08:00
i2target ( options . hi_bit_nr , entry - > opcode - > first ) ,
i2target ( options . hi_bit_nr , entry - > opcode - > last ) ) ;
lf_printf ( file , " 0, " ) ;
lf_print_table_name ( file , entry ) ;
}
lf_printf ( file , " }, \n " ) ;
}
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_table_end ( lf * file , gen_entry * table , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
ASSERT ( depth = = 0 ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( table - > opcode_rule - > gen = = array_gen )
{
lf_printf ( file , " }; \n " ) ;
}
1999-04-16 09:35:26 +08:00
}
/****************************************************************/
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_goto_switch_name ( lf * file , gen_entry * entry )
1999-04-16 09:35:26 +08:00
{
lf_printf ( file , " case_ " ) ;
if ( entry - > opcode = = NULL )
{
print_function_name ( file ,
entry - > insns - > insn - > name ,
entry - > insns - > insn - > format_name ,
NULL ,
entry - > expanded_bits ,
( options . gen . icache
? function_name_prefix_icache
: function_name_prefix_semantics ) ) ;
}
else
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_print_table_name ( file , entry ) ;
1999-04-16 09:35:26 +08:00
}
}
static void
print_goto_switch_table_leaf ( lf * file ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
gen_entry * entry , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
ASSERT ( entry - > parent ! = NULL ) ;
ASSERT ( depth = = 0 ) ;
ASSERT ( entry - > parent - > opcode_rule - > gen = = goto_switch_gen ) ;
ASSERT ( entry - > parent - > opcode ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
lf_printf ( file , " /* %d */ && " , entry - > opcode_nr ) ;
if ( entry - > combined_parent ! = NULL )
print_goto_switch_name ( file , entry - > combined_parent ) ;
else
print_goto_switch_name ( file , entry ) ;
lf_printf ( file , " , \n " ) ;
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_goto_switch_break ( lf * file , gen_entry * entry )
1999-04-16 09:35:26 +08:00
{
lf_printf ( file , " goto break_ " ) ;
lf_print_table_name ( file , entry - > parent ) ;
lf_printf ( file , " ; \n " ) ;
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_goto_switch_table ( lf * file , gen_entry * table )
1999-04-16 09:35:26 +08:00
{
lf_printf ( file , " const static void * " ) ;
lf_print_table_name ( file , table ) ;
lf_printf ( file , " [] = { \n " ) ;
lf_indent ( file , + 2 ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
gen_entry_traverse_tree ( file , table , 0 , NULL /*start */ ,
print_goto_switch_table_leaf , NULL /*end */ ,
NULL /*data */ ) ;
1999-04-16 09:35:26 +08:00
lf_indent ( file , - 2 ) ;
lf_printf ( file , " }; \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
void print_idecode_switch ( lf * file , gen_entry * table , const char * result ) ;
1999-04-16 09:35:26 +08:00
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch_start ( lf * file , gen_entry * table , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
/* const char *result = data; */
ASSERT ( depth = = 0 ) ;
ASSERT ( table - > opcode_rule - > gen = = switch_gen
| | table - > opcode_rule - > gen = = goto_switch_gen
| | table - > opcode_rule - > gen = = padded_switch_gen ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
if ( table - > opcode - > is_boolean
| | table - > opcode_rule - > gen = = switch_gen
| | table - > opcode_rule - > gen = = padded_switch_gen )
{
lf_printf ( file , " switch (EXTRACTED%d (instruction_%d, %d, %d)) \n " ,
options . insn_bit_size ,
table - > opcode_rule - > word_nr ,
i2target ( options . hi_bit_nr , table - > opcode - > first ) ,
i2target ( options . hi_bit_nr , table - > opcode - > last ) ) ;
lf_indent ( file , + 2 ) ;
lf_printf ( file , " { \n " ) ;
}
else if ( table - > opcode_rule - > gen = = goto_switch_gen )
{
if ( table - > parent ! = NULL
& & ( table - > parent - > opcode_rule - > gen = = switch_gen
| | table - > parent - > opcode_rule - > gen = = goto_switch_gen
| | table - > parent - > opcode_rule - > gen = = padded_switch_gen ) )
{
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
}
print_goto_switch_table ( file , table ) ;
lf_printf ( file , " ASSERT (EXTRACTED%d (instruction_%d, %d, %d) \n " ,
options . insn_bit_size ,
table - > opcode - > word_nr ,
i2target ( options . hi_bit_nr , table - > opcode - > first ) ,
i2target ( options . hi_bit_nr , table - > opcode - > last ) ) ;
lf_printf ( file , " < (sizeof ( " ) ;
lf_print_table_name ( file , table ) ;
lf_printf ( file , " ) / sizeof(void*))); \n " ) ;
lf_printf ( file , " goto * " ) ;
lf_print_table_name ( file , table ) ;
lf_printf ( file , " [EXTRACTED%d (instruction_%d, %d, %d)]; \n " ,
options . insn_bit_size ,
table - > opcode - > word_nr ,
i2target ( options . hi_bit_nr , table - > opcode - > first ) ,
i2target ( options . hi_bit_nr , table - > opcode - > last ) ) ;
}
else
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
ASSERT ( " bad switch " = = NULL ) ;
1999-04-16 09:35:26 +08:00
}
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch_leaf ( lf * file , gen_entry * entry , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
const char * result = data ;
ASSERT ( entry - > parent ! = NULL ) ;
ASSERT ( depth = = 0 ) ;
ASSERT ( entry - > parent - > opcode_rule - > gen = = switch_gen
| | entry - > parent - > opcode_rule - > gen = = goto_switch_gen
| | entry - > parent - > opcode_rule - > gen = = padded_switch_gen ) ;
ASSERT ( entry - > parent - > opcode ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* skip over any instructions combined into another entry */
if ( entry - > combined_parent ! = NULL )
return ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( entry - > parent - > opcode - > is_boolean & & entry - > opcode_nr = = 0 )
1999-04-16 09:35:26 +08:00
{
/* case: boolean false target */
lf_printf ( file , " case %d: \n " , entry - > parent - > opcode - > boolean_constant ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
else if ( entry - > parent - > opcode - > is_boolean & & entry - > opcode_nr ! = 0 )
1999-04-16 09:35:26 +08:00
{
/* case: boolean true case */
lf_printf ( file , " default: \n " ) ;
}
else if ( entry - > parent - > opcode_rule - > gen = = switch_gen
| | entry - > parent - > opcode_rule - > gen = = padded_switch_gen )
{
/* case: <opcode-nr> - switch */
gen_entry * cob ;
for ( cob = entry ; cob ! = NULL ; cob = cob - > combined_next )
lf_printf ( file , " case %d: \n " , cob - > opcode_nr ) ;
}
else if ( entry - > parent - > opcode_rule - > gen = = goto_switch_gen )
{
/* case: <opcode-nr> - goto-switch */
print_goto_switch_name ( file , entry ) ;
lf_printf ( file , " : \n " ) ;
}
else
{
ERROR ( " bad switch " ) ;
}
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 4 ) ;
{
if ( entry - > opcode = = NULL )
{
/* switch calling leaf */
ASSERT ( entry - > nr_insns = = 1 ) ;
print_idecode_ifetch ( file , entry - > nr_prefetched_words ,
entry - > insns - > semantic - > nr_prefetched_words ) ;
switch ( options . gen . code )
{
case generate_jumps :
lf_printf ( file , " goto " ) ;
break ;
case generate_calls :
lf_printf ( file , " %s " , result ) ;
break ;
}
print_function_name ( file ,
entry - > insns - > insn - > name ,
entry - > insns - > insn - > format_name ,
NULL ,
entry - > expanded_bits ,
( options . gen . icache
? function_name_prefix_icache
: function_name_prefix_semantics ) ) ;
if ( options . gen . code = = generate_calls )
{
lf_printf ( file , " ( " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_semantic_function_actual ( file ,
entry - > insns - > semantic - >
nr_prefetched_words ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " ) " ) ;
}
lf_printf ( file , " ; \n " ) ;
}
else if ( entry - > opcode_rule - > gen = = switch_gen
| | entry - > opcode_rule - > gen = = goto_switch_gen
| | entry - > opcode_rule - > gen = = padded_switch_gen )
{
/* switch calling switch */
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
print_idecode_ifetch ( file , entry - > parent - > nr_prefetched_words ,
entry - > nr_prefetched_words ) ;
print_idecode_switch ( file , entry , result ) ;
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
else
{
/* switch looking up a table */
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
print_idecode_ifetch ( file , entry - > parent - > nr_prefetched_words ,
entry - > nr_prefetched_words ) ;
print_idecode_table ( file , entry , result ) ;
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
if ( entry - > parent - > opcode - > is_boolean
| | entry - > parent - > opcode_rule - > gen = = switch_gen
| | entry - > parent - > opcode_rule - > gen = = padded_switch_gen )
{
lf_printf ( file , " break; \n " ) ;
}
else if ( entry - > parent - > opcode_rule - > gen = = goto_switch_gen )
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_goto_switch_break ( file , entry ) ;
1999-04-16 09:35:26 +08:00
}
else
{
ERROR ( " bad switch " ) ;
}
}
lf_indent ( file , - 4 ) ;
lf_printf ( file , " } \n " ) ;
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch_illegal ( lf * file , const char * result )
1999-04-16 09:35:26 +08:00
{
lf_indent ( file , + 2 ) ;
print_idecode_invalid ( file , result , invalid_illegal ) ;
lf_printf ( file , " break; \n " ) ;
lf_indent ( file , - 2 ) ;
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch_end ( lf * file , gen_entry * table , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
const char * result = data ;
ASSERT ( depth = = 0 ) ;
ASSERT ( table - > opcode_rule - > gen = = switch_gen
| | table - > opcode_rule - > gen = = goto_switch_gen
| | table - > opcode_rule - > gen = = padded_switch_gen ) ;
ASSERT ( table - > opcode ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
if ( table - > opcode - > is_boolean )
{
lf_printf ( file , " } \n " ) ;
lf_indent ( file , - 2 ) ;
}
else if ( table - > opcode_rule - > gen = = switch_gen
| | table - > opcode_rule - > gen = = padded_switch_gen )
{
lf_printf ( file , " default: \n " ) ;
lf_indent ( file , + 2 ) ;
if ( table - > nr_entries = = table - > opcode - > nr_opcodes )
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_sim_engine_abort ( file ,
" Internal error - bad switch generated " ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " %sNULL_CIA; \n " , result ) ;
lf_printf ( file , " break; \n " ) ;
}
else
{
print_idecode_switch_illegal ( file , result ) ;
}
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
lf_indent ( file , - 2 ) ;
}
else if ( table - > opcode_rule - > gen = = goto_switch_gen )
{
lf_printf ( file , " illegal_ " ) ;
lf_print_table_name ( file , table ) ;
lf_printf ( file , " : \n " ) ;
print_idecode_invalid ( file , result , invalid_illegal ) ;
lf_printf ( file , " break_ " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_print_table_name ( file , table ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " :; \n " ) ;
if ( table - > parent ! = NULL
& & ( table - > parent - > opcode_rule - > gen = = switch_gen
| | table - > parent - > opcode_rule - > gen = = goto_switch_gen
| | table - > parent - > opcode_rule - > gen = = padded_switch_gen ) )
{
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
}
else
{
ERROR ( " bad switch " ) ;
}
}
void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch ( lf * file , gen_entry * table , const char * result )
1999-04-16 09:35:26 +08:00
{
gen_entry_traverse_tree ( file , table ,
0 ,
print_idecode_switch_start ,
print_idecode_switch_leaf ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch_end , ( void * ) result ) ;
1999-04-16 09:35:26 +08:00
}
static void
print_idecode_switch_function_header ( lf * file ,
gen_entry * table ,
int is_function_definition ,
int nr_prefetched_words )
{
lf_printf ( file , " \n " ) ;
if ( options . gen . code = = generate_calls )
{
lf_printf ( file , " static " ) ;
if ( options . gen . icache )
{
lf_printf ( file , " idecode_semantic * " ) ;
}
else
{
lf_printf ( file , " unsigned_word " ) ;
}
if ( is_function_definition )
{
lf_printf ( file , " \n " ) ;
}
else
{
lf_printf ( file , " " ) ;
}
lf_print_table_name ( file , table ) ;
lf_printf ( file , " \n ( " ) ;
print_icache_function_formal ( file , nr_prefetched_words ) ;
lf_printf ( file , " ) " ) ;
if ( ! is_function_definition )
{
lf_printf ( file , " ; " ) ;
}
lf_printf ( file , " \n " ) ;
}
if ( options . gen . code = = generate_jumps & & is_function_definition )
{
lf_indent ( file , - 1 ) ;
lf_print_table_name ( file , table ) ;
lf_printf ( file , " : \n " ) ;
lf_indent ( file , + 1 ) ;
}
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
idecode_declare_if_switch ( lf * file , gen_entry * table , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ( table - > opcode_rule - > gen = = switch_gen | | table - > opcode_rule - > gen = = goto_switch_gen | | table - > opcode_rule - > gen = = padded_switch_gen ) & & table - > parent ! = NULL /* don't declare the top one yet */
1999-04-16 09:35:26 +08:00
& & table - > parent - > opcode_rule - > gen = = array_gen )
{
print_idecode_switch_function_header ( file ,
table ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
0 /*isnt function definition */ ,
1999-04-16 09:35:26 +08:00
0 ) ;
}
}
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
idecode_expand_if_switch ( lf * file , gen_entry * table , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ( table - > opcode_rule - > gen = = switch_gen | | table - > opcode_rule - > gen = = goto_switch_gen | | table - > opcode_rule - > gen = = padded_switch_gen ) & & table - > parent ! = NULL /* don't expand the top one yet */
1999-04-16 09:35:26 +08:00
& & table - > parent - > opcode_rule - > gen = = array_gen )
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch_function_header ( file ,
table ,
1 /*is function definition */ ,
0 ) ;
1999-04-16 09:35:26 +08:00
if ( options . gen . code = = generate_calls )
{
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_switch ( file , table , " return " ) ;
1999-04-16 09:35:26 +08:00
if ( options . gen . code = = generate_calls )
{
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
}
}
/****************************************************************/
void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_lookups ( lf * file , gen_entry * table , cache_entry * cache_rules )
1999-04-16 09:35:26 +08:00
{
int depth ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* output switch function declarations where needed by tables */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
gen_entry_traverse_tree ( file , table , 1 , idecode_declare_if_switch , /* START */
NULL , NULL , NULL ) ;
1999-04-16 09:35:26 +08:00
/* output tables where needed */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
for ( depth = gen_entry_depth ( table ) ; depth > 0 ; depth - - )
1999-04-16 09:35:26 +08:00
{
gen_entry_traverse_tree ( file , table ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1 - depth ,
1999-04-16 09:35:26 +08:00
print_idecode_table_start ,
print_idecode_table_leaf ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_table_end , NULL ) ;
1999-04-16 09:35:26 +08:00
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* output switch functions where needed */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
gen_entry_traverse_tree ( file , table , 1 , idecode_expand_if_switch , /* START */
NULL , NULL , NULL ) ;
1999-04-16 09:35:26 +08:00
}
void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_body ( lf * file , gen_entry * table , const char * result )
1999-04-16 09:35:26 +08:00
{
if ( table - > opcode_rule - > gen = = switch_gen
| | table - > opcode_rule - > gen = = goto_switch_gen
| | table - > opcode_rule - > gen = = padded_switch_gen )
{
print_idecode_switch ( file , table , result ) ;
}
else
{
print_idecode_table ( file , table , result ) ;
}
}
/****************************************************************/
#if 0
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_jump ( lf * file , int is_tail )
1999-04-16 09:35:26 +08:00
{
if ( is_tail )
{
lf_putstr ( file , " if (keep_running != NULL && !*keep_running) \n " ) ;
lf_putstr ( file , " cpu_halt(cpu, nia, was_continuing, 0/*na*/); \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
if ( ! options . generate_smp )
{
lf_putstr ( file , " if (WITH_EVENTS) { \n " ) ;
lf_putstr ( file , " if (event_queue_tick(events)) { \n " ) ;
lf_putstr ( file , " cpu_set_program_counter(cpu, nia); \n " ) ;
lf_putstr ( file , " event_queue_process(events); \n " ) ;
lf_putstr ( file , " nia = cpu_get_program_counter(cpu); \n " ) ;
lf_putstr ( file , " } \n " ) ;
lf_putstr ( file , " } \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
if ( options . generate_smp )
{
if ( is_tail )
{
lf_putstr ( file , " cpu_set_program_counter(cpu, nia); \n " ) ;
}
lf_putstr ( file , " if (WITH_EVENTS) { \n " ) ;
lf_putstr ( file , " current_cpu += 1; \n " ) ;
lf_putstr ( file , " if (current_cpu >= nr_cpus) { \n " ) ;
lf_putstr ( file , " if (event_queue_tick(events)) { \n " ) ;
lf_putstr ( file , " event_queue_process(events); \n " ) ;
lf_putstr ( file , " } \n " ) ;
lf_putstr ( file , " current_cpu = 0; \n " ) ;
lf_putstr ( file , " } \n " ) ;
lf_putstr ( file , " } \n " ) ;
lf_putstr ( file , " else { \n " ) ;
lf_putstr ( file , " current_cpu = (current_cpu + 1) % nr_cpus; \n " ) ;
lf_putstr ( file , " } \n " ) ;
lf_putstr ( file , " cpu = cpus[current_cpu]; \n " ) ;
lf_putstr ( file , " nia = cpu_get_program_counter(cpu); \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
if ( options . gen . icache )
{
lf_putstr ( file , " cache_entry = cpu_icache_entry(cpu, nia); \n " ) ;
lf_putstr ( file , " if (cache_entry->address == nia) { \n " ) ;
lf_putstr ( file , " /* cache hit */ \n " ) ;
lf_putstr ( file , " goto *cache_entry->semantic; \n " ) ;
lf_putstr ( file , " } \n " ) ;
if ( is_tail )
{
lf_putstr ( file , " goto cache_miss; \n " ) ;
}
}
if ( ! options . gen . icache & & is_tail )
{
lf_printf ( file , " goto idecode; \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
}
# endif
#if 0
static void
print_jump_insn ( lf * file ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
insn_entry * instruction ,
insn_bits * expanded_bits ,
opcode_field * opcodes , cache_entry * cache_rules )
1999-04-16 09:35:26 +08:00
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* what we are for the moment */
lf_printf ( file , " \n " ) ;
print_my_defines ( file , expanded_bits , instruction - > name ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* output the icache entry */
if ( options . gen . icache )
{
lf_printf ( file , " \n " ) ;
lf_indent ( file , - 1 ) ;
print_function_name ( file ,
instruction - > name ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
expanded_bits , function_name_prefix_icache ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " : \n " ) ;
lf_indent ( file , + 1 ) ;
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
lf_putstr ( file , " const unsigned_word cia = nia; \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_itrace ( file , instruction , 1 /*putting-value-in-cache */ ) ;
1999-04-16 09:35:26 +08:00
print_idecode_validate ( file , instruction , opcodes ) ;
lf_printf ( file , " \n " ) ;
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_icache_body ( file , instruction , expanded_bits , cache_rules , 0 , /*use_defines */
1999-04-16 09:35:26 +08:00
put_values_in_icache ) ;
lf_printf ( file , " cache_entry->address = nia; \n " ) ;
lf_printf ( file , " cache_entry->semantic = && " ) ;
print_function_name ( file ,
instruction - > name ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
expanded_bits , function_name_prefix_semantics ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " ; \n " ) ;
if ( options . gen . semantic_icache )
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_semantic_body ( file , instruction , expanded_bits , opcodes ) ;
print_jump ( file , 1 /*is-tail */ ) ;
1999-04-16 09:35:26 +08:00
}
else
{
lf_printf ( file , " /* goto " ) ;
print_function_name ( file ,
instruction - > name ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
expanded_bits , function_name_prefix_semantics ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " ; */ \n " ) ;
}
lf_indent ( file , - 2 ) ;
lf_putstr ( file , " } \n " ) ;
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* print the semantics */
lf_printf ( file , " \n " ) ;
lf_indent ( file , - 1 ) ;
print_function_name ( file ,
instruction - > name ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
expanded_bits , function_name_prefix_semantics ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " : \n " ) ;
lf_indent ( file , + 1 ) ;
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
lf_putstr ( file , " const unsigned_word cia = nia; \n " ) ;
print_icache_body ( file ,
instruction ,
expanded_bits ,
cache_rules ,
( options . gen . direct_access
? define_variables
: declare_variables ) ,
( options . gen . icache
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
? get_values_from_icache : do_not_use_icache ) ) ;
print_semantic_body ( file , instruction , expanded_bits , opcodes ) ;
1999-04-16 09:35:26 +08:00
if ( options . gen . direct_access )
print_icache_body ( file ,
instruction ,
expanded_bits ,
cache_rules ,
undef_variables ,
( options . gen . icache
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
? get_values_from_icache : do_not_use_icache ) ) ;
print_jump ( file , 1 /*is tail */ ) ;
1999-04-16 09:35:26 +08:00
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
# endif
#if 0
static void
print_jump_definition ( lf * file ,
gen_entry * entry ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
insn_entry * insn , int depth , void * data )
1999-04-16 09:35:26 +08:00
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
cache_entry * cache_rules = ( cache_entry * ) data ;
1999-04-16 09:35:26 +08:00
if ( options . generate_expanded_instructions )
{
ASSERT ( entry - > nr_insns = = 1
& & entry - > opcode = = NULL
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
& & entry - > parent ! = NULL & & entry - > parent - > opcode ! = NULL ) ;
1999-04-16 09:35:26 +08:00
ASSERT ( entry - > nr_insns = = 1
& & entry - > opcode = = NULL
& & entry - > parent ! = NULL
& & entry - > parent - > opcode ! = NULL
& & entry - > parent - > opcode_rule ! = NULL ) ;
print_jump_insn ( file ,
entry - > insns - > words [ 0 ] - > insn ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
entry - > expanded_bits , entry - > opcode , cache_rules ) ;
1999-04-16 09:35:26 +08:00
}
else
{
print_jump_insn ( file ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
instruction - > words [ 0 ] - > insn , NULL , NULL , cache_rules ) ;
1999-04-16 09:35:26 +08:00
}
}
# endif
#if 0
static void
print_jump_internal_function ( lf * file ,
gen_entry * table ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
function_entry * function , void * data )
1999-04-16 09:35:26 +08:00
{
if ( function - > is_internal )
{
lf_printf ( file , " \n " ) ;
lf_print__line_ref ( file , function - > line ) ;
lf_indent ( file , - 1 ) ;
print_function_name ( file ,
function - > name ,
NULL ,
( options . gen . icache
? function_name_prefix_icache
: function_name_prefix_semantics ) ) ;
lf_printf ( file , " : \n " ) ;
lf_indent ( file , + 1 ) ;
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
lf_printf ( file , " const unsigned_word cia = nia; \n " ) ;
table_print_code ( file , function - > code ) ;
lf_print__internal_ref ( file ) ;
print_sim_engine_abort ( file , " Internal function must longjump " ) ;
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
}
# endif
#if 0
static void
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_jump_until_stop_body ( lf * file ,
insn_table * table , cache_table * cache_rules )
1999-04-16 09:35:26 +08:00
{
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 2 ) ;
lf_putstr ( file , " jmp_buf halt; \n " ) ;
lf_putstr ( file , " jmp_buf restart; \n " ) ;
lf_putstr ( file , " sim_cpu *cpu = NULL; \n " ) ;
lf_putstr ( file , " unsigned_word nia = -1; \n " ) ;
lf_putstr ( file , " instruction_word instruction = 0; \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ( code & generate_with_icache ) )
{
lf_putstr ( file , " idecode_cache *cache_entry = NULL; \n " ) ;
}
if ( generate_smp )
{
lf_putstr ( file , " int current_cpu = -1; \n " ) ;
}
1999-04-16 09:35:26 +08:00
/* all the switches and tables - they know about jumping */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_lookups ( file , table , cache_rules ) ;
1999-04-16 09:35:26 +08:00
/* start the simulation up */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ( code & generate_with_icache ) )
{
lf_putstr ( file , " \n " ) ;
lf_putstr ( file , " { \n " ) ;
lf_putstr ( file , " int cpu_nr; \n " ) ;
lf_putstr ( file , " for (cpu_nr = 0; cpu_nr < nr_cpus; cpu_nr++) \n " ) ;
lf_putstr ( file , " cpu_flush_icache(cpus[cpu_nr]); \n " ) ;
lf_putstr ( file , " } \n " ) ;
}
1999-04-16 09:35:26 +08:00
lf_putstr ( file , " \n " ) ;
lf_putstr ( file , " psim_set_halt_and_restart(system, &halt, &restart); \n " ) ;
lf_putstr ( file , " \n " ) ;
lf_putstr ( file , " if (setjmp(halt)) \n " ) ;
lf_putstr ( file , " return; \n " ) ;
lf_putstr ( file , " \n " ) ;
lf_putstr ( file , " setjmp(restart); \n " ) ;
lf_putstr ( file , " \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ! generate_smp )
{
lf_putstr ( file , " cpu = cpus[0]; \n " ) ;
lf_putstr ( file , " nia = cpu_get_program_counter(cpu); \n " ) ;
}
else
{
lf_putstr ( file , " current_cpu = psim_last_cpu(system); \n " ) ;
}
1999-04-16 09:35:26 +08:00
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ! ( code & generate_with_icache ) )
{
lf_printf ( file , " \n " ) ;
lf_indent ( file , - 1 ) ;
lf_printf ( file , " idecode: \n " ) ;
lf_indent ( file , + 1 ) ;
}
1999-04-16 09:35:26 +08:00
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_jump ( file , 0 /*is_tail */ ) ;
1999-04-16 09:35:26 +08:00
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
if ( ( code & generate_with_icache ) )
{
lf_indent ( file , - 1 ) ;
lf_printf ( file , " cache_miss: \n " ) ;
lf_indent ( file , + 1 ) ;
}
1999-04-16 09:35:26 +08:00
lf_putstr ( file , " instruction \n " ) ;
lf_putstr ( file , " = vm_instruction_map_read(cpu_instruction_map(cpu), \n " ) ;
lf_putstr ( file , " cpu, nia); \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_body ( file , table , " /*IGORE*/ " ) ;
1999-04-16 09:35:26 +08:00
/* print out a table of all the internals functions */
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
insn_table_traverse_function ( table ,
file , NULL , print_jump_internal_function ) ;
1999-04-16 09:35:26 +08:00
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
/* print out a table of all the instructions */
1999-04-16 09:35:26 +08:00
if ( generate_expanded_instructions )
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
insn_table_traverse_tree ( table , file , cache_rules , 1 , NULL , /* start */
print_jump_definition , /* leaf */
NULL , /* end */
NULL ) ; /* padding */
1999-04-16 09:35:26 +08:00
else
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
insn_table_traverse_insn ( table ,
file , cache_rules , print_jump_definition ) ;
1999-04-16 09:35:26 +08:00
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
}
# endif
/****************************************************************/
/* Output code to do any final checks on the decoded instruction.
This includes things like verifying any on decoded fields have the
correct value and checking that ( for floating point ) floating point
hardware isn ' t disabled */
void
print_idecode_validate ( lf * file ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
insn_entry * instruction , insn_opcodes * opcode_paths )
1999-04-16 09:35:26 +08:00
{
/* Validate: unchecked instruction fields
If any constant fields in the instruction were not checked by the
idecode tables , output code to check that they have the correct
value here */
{
int nr_checks = 0 ;
int word_nr ;
lf_printf ( file , " \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #if defined (WITH_RESERVED_BITS) \n " ) ;
lf_printf ( file , " /* validate: " ) ;
print_insn_words ( file , instruction ) ;
lf_printf ( file , " */ \n " ) ;
for ( word_nr = 0 ; word_nr < instruction - > nr_words ; word_nr + + )
{
insn_uint check_mask = 0 ;
insn_uint check_val = 0 ;
insn_word_entry * word = instruction - > word [ word_nr ] ;
int bit_nr ;
/* form check_mask/check_val containing what needs to be checked
in the instruction */
for ( bit_nr = 0 ; bit_nr < options . insn_bit_size ; bit_nr + + )
{
insn_bit_entry * bit = word - > bit [ bit_nr ] ;
insn_field_entry * field = bit - > field ;
/* Make space for the next bit */
check_mask < < = 1 ;
check_val < < = 1 ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* Only need to validate constant (and reserved)
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
bits . Skip any others */
1999-04-16 09:35:26 +08:00
if ( field - > type ! = insn_field_int
& & field - > type ! = insn_field_reserved )
continue ;
/* Look through the list of opcode paths that lead to this
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
instruction . See if any have failed to check the
relevant bit */
1999-04-16 09:35:26 +08:00
if ( opcode_paths ! = NULL )
{
insn_opcodes * entry ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
for ( entry = opcode_paths ; entry ! = NULL ; entry = entry - > next )
1999-04-16 09:35:26 +08:00
{
opcode_field * opcode ;
for ( opcode = entry - > opcode ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
opcode ! = NULL ; opcode = opcode - > parent )
1999-04-16 09:35:26 +08:00
{
if ( opcode - > word_nr = = word_nr
& & opcode - > first < = bit_nr
& & opcode - > last > = bit_nr )
/* we've decoded on this bit */
break ;
}
if ( opcode = = NULL )
/* the bit wasn't decoded on */
break ;
}
if ( entry = = NULL )
/* all the opcode paths decoded on BIT_NR, no need
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
to check it */
1999-04-16 09:35:26 +08:00
continue ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
check_mask | = 1 ;
check_val | = bit - > value ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* if any bits not checked by opcode tables, output code to check them */
if ( check_mask )
{
if ( nr_checks = = 0 )
{
lf_printf ( file , " if (WITH_RESERVED_BITS) \n " ) ;
lf_printf ( file , " { \n " ) ;
lf_indent ( file , + 4 ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
nr_checks + + ;
1999-04-16 09:35:26 +08:00
if ( options . insn_bit_size > 32 )
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file , " if ((instruction_%d \n " , word_nr ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " & UNSIGNED64 (0x%08lx%08lx)) \n " ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
( unsigned long ) ( check_mask > > 32 ) ,
( unsigned long ) ( check_mask ) ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " != UNSIGNED64 (0x%08lx%08lx)) \n " ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
( unsigned long ) ( check_val > > 32 ) ,
( unsigned long ) ( check_val ) ) ;
1999-04-16 09:35:26 +08:00
}
else
{
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file ,
" if ((instruction_%d & 0x%08lx) != 0x%08lx) \n " ,
word_nr , ( unsigned long ) ( check_mask ) ,
( unsigned long ) ( check_val ) ) ;
1999-04-16 09:35:26 +08:00
}
lf_indent ( file , + 2 ) ;
print_idecode_invalid ( file , " return " , invalid_illegal ) ;
lf_indent ( file , - 2 ) ;
}
}
if ( nr_checks > 0 )
{
lf_indent ( file , - 4 ) ;
lf_printf ( file , " } \n " ) ;
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_indent_suppress ( file ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " #endif \n " ) ;
}
/* Validate: Floating Point hardware
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
If the simulator is being built with out floating point hardware
( different to it being disabled in the MSR ) then floating point
instructions are invalid */
{
if ( filter_is_member ( instruction - > flags , " f " ) )
{
lf_printf ( file , " \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #if defined(CURRENT_FLOATING_POINT) \n " ) ;
lf_printf ( file , " /* Validate: FP hardware exists */ \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file ,
" if (CURRENT_FLOATING_POINT != HARD_FLOATING_POINT) { \n " ) ;
1999-04-16 09:35:26 +08:00
lf_indent ( file , + 2 ) ;
print_idecode_invalid ( file , " return " , invalid_illegal ) ;
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #endif \n " ) ;
}
}
/* Validate: Floating Point available
If floating point is not available , we enter a floating point
unavailable interrupt into the cache instead of the instruction
proper .
The PowerPC spec requires a CSI after MSR [ FP ] is changed and when
ever a CSI occures we flush the instruction cache . */
{
if ( filter_is_member ( instruction - > flags , " f " ) )
{
lf_printf ( file , " \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #if defined(IS_FP_AVAILABLE) \n " ) ;
lf_printf ( file , " /* Validate: FP available according to cpu */ \n " ) ;
lf_printf ( file , " if (!IS_FP_AVAILABLE) { \n " ) ;
lf_indent ( file , + 2 ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
print_idecode_invalid ( file , " return " , invalid_fp_unavailable ) ;
1999-04-16 09:35:26 +08:00
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #endif \n " ) ;
}
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
/* Validate: Validate Instruction in correct slot
Some architectures place restrictions on the slot that an
instruction can be issued in */
{
if ( filter_is_member ( instruction - > options , " s " )
| | options . gen . slot_verification )
{
lf_printf ( file , " \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #if defined(IS_WRONG_SLOT) \n " ) ;
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
lf_printf ( file ,
" /* Validate: Instruction issued in correct slot */ \n " ) ;
1999-04-16 09:35:26 +08:00
lf_printf ( file , " if (IS_WRONG_SLOT) { \n " ) ;
lf_indent ( file , + 2 ) ;
print_idecode_invalid ( file , " return " , invalid_wrong_slot ) ;
lf_indent ( file , - 2 ) ;
lf_printf ( file , " } \n " ) ;
lf_indent_suppress ( file ) ;
lf_printf ( file , " #endif \n " ) ;
}
}
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
1999-04-16 09:35:26 +08:00
}
/****************************************************************/
void
print_idecode_issue_function_header ( lf * file ,
const char * processor ,
function_decl_type decl_type ,
int nr_prefetched_words )
{
int indent ;
lf_printf ( file , " \n " ) ;
switch ( decl_type )
{
case is_function_declaration :
lf_print__function_type_function ( file , print_semantic_function_type ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
" INLINE_IDECODE " , " " ) ;
1999-04-16 09:35:26 +08:00
break ;
case is_function_definition :
lf_print__function_type_function ( file , print_semantic_function_type ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
" INLINE_IDECODE " , " \n " ) ;
1999-04-16 09:35:26 +08:00
break ;
case is_function_variable :
print_semantic_function_type ( file ) ;
lf_printf ( file , " (* " ) ;
break ;
}
indent = print_function_name ( file ,
" issue " ,
NULL ,
processor ,
2002-11-21 Andrew Cagney <ac131313@redhat.com>
* filter.c: Re-indent.
* filter.h, filter_host.h, gen-engine.c, gen-engine.h: Ditto.
* gen-icache.c, gen-icache.h, gen-idecode.c: Ditto.
* gen-idecode.h, gen-itable.c, gen-itable.h: Ditto.
* gen-model.c, gen-model.h, gen-semantics.c: Ditto.
* gen-semantics.h, gen-support.c, gen-support.h: Ditto.
* gen.c, gen.h, igen.c, igen.h, ld-cache.c, ld-cache.h: Ditto.
* ld-decode.c, ld-decode.h, ld-insn.c, ld-insn.h, lf.c: Ditto.
* lf.h, misc.c, misc.h, table.c, table.h: Ditto.
2002-11-22 12:20:49 +08:00
NULL , function_name_prefix_idecode ) ;
1999-04-16 09:35:26 +08:00
switch ( decl_type )
{
case is_function_definition :
indent + = lf_printf ( file , " ( " ) ;
break ;
case is_function_declaration :
lf_putstr ( file , " \n ( " ) ;
indent = 1 ;
break ;
case is_function_variable :
lf_putstr ( file , " ) \n ( " ) ;
indent = 1 ;
break ;
}
lf_indent ( file , + indent ) ;
print_semantic_function_formal ( file , nr_prefetched_words ) ;
lf_putstr ( file , " ) " ) ;
lf_indent ( file , - indent ) ;
switch ( decl_type )
{
case is_function_definition :
lf_printf ( file , " \n " ) ;
break ;
case is_function_declaration :
case is_function_variable :
lf_putstr ( file , " ; \n " ) ;
break ;
}
}
void
print_idecode_globals ( lf * file )
{
lf_printf ( file , " enum { \n " ) ;
lf_printf ( file , " /* greater or equal to zero => table */ \n " ) ;
lf_printf ( file , " function_entry = -1, \n " ) ;
lf_printf ( file , " boolean_entry = -2, \n " ) ;
lf_printf ( file , " }; \n " ) ;
lf_printf ( file , " \n " ) ;
lf_printf ( file , " typedef struct _idecode_table_entry { \n " ) ;
lf_printf ( file , " int shift; \n " ) ;
lf_printf ( file , " unsigned%d mask; \n " , options . insn_bit_size ) ;
lf_printf ( file , " unsigned%d value; \n " , options . insn_bit_size ) ;
lf_printf ( file , " void *function_or_table; \n " ) ;
lf_printf ( file , " } idecode_table_entry; \n " ) ;
}