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.

125 lines
3.3 KiB

/* BEGIN_LEGAL
Copyright (c) 2021 Intel Corporation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
END_LEGAL */
#include "xed/xed-interface.h"
#include "xed/xed-chk-enc2-m64-a64.h"
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
static xed_uint32_t test_0_xed_enc_lea_rm_q_bisd32_a64(xed_uint8_t* output_buffer)
{
xed_reg_enum_t dest;
xed_reg_enum_t base;
xed_reg_enum_t index;
xed_uint_t scale;
xed_int32_t disp32;
xed_enc2_req_t request;
xed_enc2_req_t_init(&request, output_buffer);
dest = XED_REG_XMM5; // INTENTIONAL ERROR FOR EXAMPLE. THIS SHOULD BE A GPR LIKE R11
base = XED_REG_R12;
index = XED_REG_R13;
scale = 1;
disp32 = 0x11223344;
xed_enc_lea_r64_m_bisd32_a64_chk(&request /*req*/,dest /*gpr64*/,base /*gpr64*/,index /*gpr64*/,scale /*scale*/,disp32 /*int32*/);
return xed_enc2_encoded_length(&request);
}
// The decoder drags in a lot of stuff to the final executable.
#define DECO
#if defined(DECO)
static void disassemble(xed_decoded_inst_t* xedd)
{
xed_bool_t ok;
xed_print_info_t pi;
#define XBUFLEN 200
char buf[XBUFLEN];
xed_init_print_info(&pi);
pi.p = xedd;
pi.blen = XBUFLEN;
pi.buf = buf;
pi.buf[0]=0; //allow use of strcat
ok = xed_format_generic(&pi);
if (ok)
printf("Disassembly: %s\n", buf);
else
printf("Disassembly: %%ERROR%%\n");
}
static int decode(xed_uint8_t* buf, xed_uint32_t len) {
xed_decoded_inst_t xedd;
xed_error_enum_t err;
xed_state_t dstate;
static int first = 1;
if (first) {
xed_tables_init();
first = 0;
}
xed_state_zero(&dstate);
dstate.mmode=XED_MACHINE_MODE_LONG_64;
xed_decoded_inst_zero_set_mode(&xedd, &dstate);
err = xed_decode(&xedd, buf, len);
if (err == XED_ERROR_NONE) {
disassemble(&xedd);
return 0;
}
printf("ERROR: %s\n", xed_error_enum_t2str(err));
return 1;
}
#endif
static void dump(xed_uint8_t* buf, xed_uint32_t len) {
xed_uint_t i;
for(i=0;i<len;i++)
printf("%02x ",buf[i]);
}
void my_error_handler(const char* fmt, va_list args) {
printf("LOCAL HANDLER FOR XED ENC2 ERROR: ");
vprintf(fmt, args);
printf(".\n");
exit(1);
}
int main(int argc, char** argv) {
xed_uint8_t output_buffer[XED_MAX_INSTRUCTION_BYTES];
xed_uint32_t enclen;
int retval=0;
xed_enc2_set_error_handler(my_error_handler);
// uncomment this line to disable runtime checking
//xed_enc2_set_check_args(0);
enclen = test_0_xed_enc_lea_rm_q_bisd32_a64(output_buffer);
printf("Encoded: ");
dump(output_buffer, enclen);
printf("\n");
#if defined(DECO)
retval = decode(output_buffer, enclen);
printf("decode returned %d\n",retval);
#endif
return retval;
(void)argc; (void)argv;
}