2015-08-26 22:19:12 +00:00
|
|
|
#include <unicorn/unicorn.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#define ADDR 0x00400000
|
|
|
|
#define SIZE 1024*64
|
|
|
|
#define OVERFLOW 1
|
|
|
|
|
2015-08-28 10:21:36 +00:00
|
|
|
int main()
|
|
|
|
{
|
2015-09-03 01:44:43 +00:00
|
|
|
ucengine *uc;
|
2015-08-28 10:21:36 +00:00
|
|
|
uint8_t *buf, *buf2;
|
|
|
|
int i;
|
|
|
|
uc_err err;
|
2015-08-26 22:19:12 +00:00
|
|
|
|
2015-09-03 01:25:59 +00:00
|
|
|
err = uc_open (UC_ARCH_X86, UC_MODE_64, &uc);
|
2015-08-28 10:21:36 +00:00
|
|
|
if (err) {
|
|
|
|
printf ("uc_open %d\n", err);
|
|
|
|
return 1;
|
|
|
|
}
|
2015-09-03 01:25:59 +00:00
|
|
|
err = uc_mem_map (uc, ADDR, SIZE, UC_PROT_ALL);
|
2015-08-28 10:21:36 +00: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 01:25:59 +00:00
|
|
|
err = uc_mem_write (uc, ADDR, buf, SIZE+OVERFLOW);
|
2015-08-28 10:21:36 +00:00
|
|
|
if (err) {
|
|
|
|
printf ("uc_mem_map %d\n", err);
|
|
|
|
return 1;
|
|
|
|
}
|
2015-09-03 01:25:59 +00:00
|
|
|
err = uc_mem_read (uc, ADDR+10, buf2, 4);
|
2015-08-28 10:21:36 +00: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-26 22:19:12 +00:00
|
|
|
}
|