2015-08-27 01:19:12 +03:00
|
|
|
#include <unicorn/unicorn.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#define ADDR 0x00400000
|
|
|
|
#define SIZE 1024*64
|
|
|
|
#define OVERFLOW 1
|
|
|
|
|
2015-08-28 13:21:36 +03:00
|
|
|
int main()
|
|
|
|
{
|
2015-09-05 06:20:32 +03:00
|
|
|
uc_engine *uc;
|
2015-08-28 13:21:36 +03:00
|
|
|
uint8_t *buf, *buf2;
|
|
|
|
int i;
|
|
|
|
uc_err err;
|
2015-08-27 01:19:12 +03:00
|
|
|
|
2015-09-03 04:25:59 +03:00
|
|
|
err = uc_open (UC_ARCH_X86, UC_MODE_64, &uc);
|
2015-08-28 13:21:36 +03:00
|
|
|
if (err) {
|
|
|
|
printf ("uc_open %d\n", err);
|
|
|
|
return 1;
|
|
|
|
}
|
2015-09-03 04:25:59 +03:00
|
|
|
err = uc_mem_map (uc, ADDR, SIZE, UC_PROT_ALL);
|
2015-08-28 13:21:36 +03:00
|
|
|
if (err) {
|
|
|
|
printf ("uc_mem_map %d\n", err);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
buf = calloc (SIZE*2, 1);
|
|
|
|
buf2 = calloc (SIZE, 1);
|
|
|
|
for (i=0;i<SIZE; i++) {
|
|
|
|
buf[i] = i & 0xff;
|
|
|
|
}
|
|
|
|
/* crash here */
|
2015-09-03 04:25:59 +03:00
|
|
|
err = uc_mem_write (uc, ADDR, buf, SIZE+OVERFLOW);
|
2015-08-28 13:21:36 +03:00
|
|
|
if (err) {
|
|
|
|
printf ("uc_mem_map %d\n", err);
|
|
|
|
return 1;
|
|
|
|
}
|
2015-09-03 04:25:59 +03:00
|
|
|
err = uc_mem_read (uc, ADDR+10, buf2, 4);
|
2015-08-28 13:21:36 +03:00
|
|
|
if (err) {
|
|
|
|
printf ("uc_mem_map %d\n", err);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (buf2[0] != 0xa) {
|
|
|
|
printf ("mem contents are wrong\n");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
printf ("OK\n");
|
|
|
|
free (buf);
|
|
|
|
free (buf2);
|
|
|
|
return 0;
|
2015-08-27 01:19:12 +03:00
|
|
|
}
|