Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

159 lines
7.2 KiB

/*
* Copyright (c) 2000, Intel Corporation
* All rights reserved.
*
* WARRANTY DISCLAIMER
*
* THESE MATERIALS ARE PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR ITS
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THESE
* MATERIALS, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* Intel Corporation is the author of the Materials, and requests that all
* problem reports or change requests be submitted to it directly at
* http://developer.intel.com/opensource.
*/
/*****************************************************************************/
/* decoder_priv.h */
/*****************************************************************************/
#ifndef _DECODER_PRIV_H_
#define _DECODER_PRIV_H_
#define EM_DECODER_MAX_CLIENTS 20
#define DEFAULT_MACHINE_TYPE EM_DECODER_CPU_P7
#define DEFAULT_MACHINE_MODE EM_DECODER_MODE_EM
typedef struct
{
int is_used;
EM_Decoder_Machine_Type machine_type;
EM_Decoder_Machine_Mode machine_mode;
void ** info_ptr; /*** after dynamic allocation, ***/
/*** info_ptr points to an array ***/
/*** of pointers. The i'th pointer ***/
/*** in the array is a ptr to the ***/
/*** client info. ***/
unsigned long flags;
} Client_Entry;
Client_Entry em_clients_table[EM_DECODER_MAX_CLIENTS];
#define FILL_PREDICATE_INFO(Inst_code, Dinfo_p) \
{ \
int pred_no = (IEL_GETDW0(Inst_code) >> EM_PREDICATE_POS) & \
((1 << EM_PREDICATE_BITS)-1); \
Dinfo_p->pred.valid = TRUE; \
Dinfo_p->pred.value = pred_no; \
Dinfo_p->pred.type = EM_DECODER_PRED_REG; \
Dinfo_p->pred.name = EM_DECODER_REG_P0 + pred_no; \
}
#define GET_BRANCH_BEHAVIOUR_BIT(Inst_code,Bit) \
{ \
unsigned int tmp; \
U64 tmp64; \
IEL_SHR(tmp64,(Inst_code),BRANCH_BEHAVIOUR_BIT); \
tmp = IEL_GETDW0(tmp64); \
(Bit) = tmp & 1; \
}
#define EM_DECODER_SET_UNC_ILLEGAL_FAULT(di) ((di)->flags |= EM_DECODER_BIT_UNC_ILLEGAL_FAULT)
/*** Static variables initialization ***/
static const char em_ver_string[] = VER_STR; /*** initialized by Makefile ***/
static const char *em_err_msg[EM_DECODER_LAST_ERROR] =
{
"",
"EM_DECODER_INVALID_SLOT_BRANCH_INST: Instruction must be in the last slot of the current bundle",
"EM_DECODER_MUST_BE_GROUP_LAST: Instruction must be the last in instruction group",
"EM_DECODER_BASE_EQUAL_DEST: Source and destination operands have the same value",
"EM_DECODER_EQUAL_DESTS: Two destination operands have the same value",
"EM_DECODER_ODD_EVEN_DESTS: Both destination floating-point registers have odd or even values",
"EM_DECODER_WRITE_TO_ZERO_REGISTER: Destination general register r0 is invalid",
"EM_DECODER_WRITE_TO_SPECIAL_FP_REGISTER: Destination floating point register is f0 or f1",
"EM_DECODER_REGISTER_VALUE_OUT_OF_RANGE: Register value is out of permitted range",
"EM_DECODER_REGISTER_RESERVED_VALUE: Register operand value is reserved",
"EM_DECODER_IMMEDIATE_VALUE_OUT_OF_RANGE: Immediate operand value is out of permitted range",
"EM_DECODER_IMMEDIATE_INVALID_VALUE: Invalid immediate operand value",
"EM_DECODER_STACK_FRAME_SIZE_OUT_OF_RANGE: Stack frame size is larger than maximum permitted value",
"EM_DECODER_LOCALS_SIZE_LARGER_STACK_FRAME: Size of locals is larger than the stack frame",
"EM_DECODER_ROTATING_SIZE_LARGER_STACK_FRAME: Size of rotating region is larger than the stack frame",
"EM_DECODER_HARD_CODED_PREDICATE_INVALID_VALUE: Invalid hard-coded predicate value",
"EM_DECODER_INVALID_PRM_OPCODE: Instruction contains an invalid opcode",
"EM_DECODER_INVALID_INST_SLOT: Instruction slot is invalid in current bundle",
"EM_DECODER_INVALID_TEMPLATE: Invalid template is specified",
"EM_DECODER_INVALID_CLIENT_ID: Invalid client id",
"EM_DECODER_NULL_PTR: A null pointer was specified in call",
"EM_DECODER_TOO_SHORT_ERR: Instruction buffer is too short for instruction",
"EM_DECODER_ASSOCIATE_MISS: There is an unassociated instruction",
"EM_DECODER_INVALID_INST_ID: Invalid instruction id",
"EM_DECODER_INVALID_MACHINE_MODE: Invalid machine mode",
"EM_DECODER_INVALID_MACHINE_TYPE: Invalid machine type",
"EM_DECODER_INTERNAL_ERROR: Internal data-base collisions"};
typedef enum
{
BEHAVIOUR_UNDEF = 0,
BEHAVIOUR_IGNORE_ON_FALSE_QP,
BEHAVIOUR_FAULT
}Behaviour_ill_opcode;
static const Behaviour_ill_opcode branch_ill_opcode[]=
{
/* 0*/ BEHAVIOUR_UNDEF,
/* 1*/ BEHAVIOUR_FAULT,
/* 2*/ BEHAVIOUR_IGNORE_ON_FALSE_QP,
/* 3*/ BEHAVIOUR_IGNORE_ON_FALSE_QP,
/* 4*/ BEHAVIOUR_FAULT,
/* 5*/ BEHAVIOUR_FAULT,
/* 6*/ BEHAVIOUR_IGNORE_ON_FALSE_QP,
/* 7*/ BEHAVIOUR_IGNORE_ON_FALSE_QP,
/* 8*/ BEHAVIOUR_FAULT,
/* 9*/ BEHAVIOUR_FAULT,
/* a*/ BEHAVIOUR_FAULT,
/* b*/ BEHAVIOUR_FAULT,
/* c*/ BEHAVIOUR_FAULT,
/* d*/ BEHAVIOUR_FAULT,
/* e*/ BEHAVIOUR_FAULT,
/* f*/ BEHAVIOUR_FAULT
};
#define PRED_BEHAVIOUR(trole, maj_op, behav) \
{ \
switch(trole) \
{ \
case(EM_TEMP_ROLE_MEM): \
case(EM_TEMP_ROLE_INT): \
case(EM_TEMP_ROLE_LONG): \
case(EM_TEMP_ROLE_FP): \
(behav) = BEHAVIOUR_IGNORE_ON_FALSE_QP; \
break; \
case(EM_TEMP_ROLE_BR): \
(behav) = branch_ill_opcode[(maj_op)]; \
break; \
default: \
(behav) = BEHAVIOUR_FAULT; \
} \
}
/* this bit is crtical for machine behaviour within
illegal branch instruction with major opcode 0 */
#define BRANCH_BEHAVIOUR_BIT 32
#endif /* _DECODER_PRIV_H_ */