notaz.gp2x.de
/
ia32rtools.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
resolve some functions
[ia32rtools.git]
/
tools
/
protoparse.h
diff --git
a/tools/protoparse.h
b/tools/protoparse.h
index
9a126cc
..
26b0e00
100644
(file)
--- a/
tools/protoparse.h
+++ b/
tools/protoparse.h
@@
-6,6
+6,7
@@
struct parsed_type {
unsigned int is_array:1;
unsigned int is_ptr:1;
unsigned int is_struct:1; // split for args
unsigned int is_array:1;
unsigned int is_ptr:1;
unsigned int is_struct:1; // split for args
+ unsigned int is_retreg:1; // register to return
};
struct parsed_proto_arg {
};
struct parsed_proto_arg {
@@
-32,8
+33,10
@@
struct parsed_proto {
unsigned int is_fptr:1;
unsigned int is_noreturn:1;
unsigned int is_unresolved:1;
unsigned int is_fptr:1;
unsigned int is_noreturn:1;
unsigned int is_unresolved:1;
+ unsigned int is_userstack:1;
unsigned int is_arg:1; // decl in func arg
unsigned int has_structarg:1;
unsigned int is_arg:1; // decl in func arg
unsigned int has_structarg:1;
+ unsigned int has_retreg:1;
};
static const char *hdrfn;
};
static const char *hdrfn;
@@
-113,14
+116,22
@@
static int do_protostrs(FILE *fhdr, const char *fname)
return -1;
}
return -1;
}
-static int get_regparm(char *dst, size_t dlen, char *p)
+static int get_regparm(char *dst, size_t dlen, char *p
, int *retreg
)
{
{
- int i, o;
+ int i = 0, o;
+
+ *retreg = 0;
if (*p != '<')
return 0;
if (*p != '<')
return 0;
- for (o = 0, i = 1; o < dlen; i++) {
+ i++;
+ if (p[i] == '*') {
+ *retreg = 1;
+ i++;
+ }
+
+ for (o = 0; o < dlen; i++) {
if (p[i] == 0)
return 0;
if (p[i] == '>')
if (p[i] == 0)
return 0;
if (p[i] == '>')
@@
-155,13
+166,14
@@
static const char *known_ptr_types[] = {
"HGLOBAL",
"HICON",
"HINSTANCE",
"HGLOBAL",
"HICON",
"HINSTANCE",
- //"HIMC", // DWORD
+ "HIMC", // DWORD in mingw, ptr in wine..
"HMODULE",
"HPALETTE",
"HRGN",
"HRSRC",
"HKEY",
"HMENU",
"HMODULE",
"HPALETTE",
"HRGN",
"HRSRC",
"HKEY",
"HMENU",
+ "HWAVEOUT",
"HWND",
"PBYTE",
"PCRITICAL_SECTION",
"HWND",
"PBYTE",
"PCRITICAL_SECTION",
@@
-301,6
+313,7
@@
static int parse_protostr(char *protostr, struct parsed_proto *pp)
char regparm[16];
char buf[256];
char cconv[32];
char regparm[16];
char buf[256];
char cconv[32];
+ int is_retreg;
int xarg = 0;
char *p, *p1;
int i, l;
int xarg = 0;
char *p, *p1;
int i, l;
@@
-389,6
+402,10
@@
static int parse_protostr(char *protostr, struct parsed_proto *pp)
pp->is_stdcall = 1; // IDA
else if (IS(cconv, "__usercall"))
pp->is_stdcall = 0; // IDA
pp->is_stdcall = 1; // IDA
else if (IS(cconv, "__usercall"))
pp->is_stdcall = 0; // IDA
+ else if (IS(cconv, "__userstack")) {
+ pp->is_stdcall = 0; // custom
+ pp->is_userstack = 1;
+ }
else if (IS(cconv, "WINAPI"))
pp->is_stdcall = 1;
else {
else if (IS(cconv, "WINAPI"))
pp->is_stdcall = 1;
else {
@@
-419,7
+436,7
@@
static int parse_protostr(char *protostr, struct parsed_proto *pp)
}
strcpy(pp->name, buf);
}
strcpy(pp->name, buf);
- ret = get_regparm(regparm, sizeof(regparm), p);
+ ret = get_regparm(regparm, sizeof(regparm), p
, &is_retreg
);
if (ret > 0) {
if (!IS(regparm, "eax") && !IS(regparm, "ax")
&& !IS(regparm, "al") && !IS(regparm, "edx:eax"))
if (ret > 0) {
if (!IS(regparm, "eax") && !IS(regparm, "ax")
&& !IS(regparm, "al") && !IS(regparm, "edx:eax"))
@@
-535,12
+552,14
@@
static int parse_protostr(char *protostr, struct parsed_proto *pp)
#endif
arg->reg = NULL;
#endif
arg->reg = NULL;
- ret = get_regparm(regparm, sizeof(regparm), p);
+ ret = get_regparm(regparm, sizeof(regparm), p
, &is_retreg
);
if (ret > 0) {
p += ret;
p = sskip(p);
arg->reg = strdup(map_reg(regparm));
if (ret > 0) {
p += ret;
p = sskip(p);
arg->reg = strdup(map_reg(regparm));
+ arg->type.is_retreg = is_retreg;
+ pp->has_retreg |= is_retreg;
}
if (strstr(arg->type.name, "int64")
}
if (strstr(arg->type.name, "int64")
@@
-664,6
+683,7
@@
static const struct parsed_proto *proto_parse(FILE *fhdr, const char *sym,
{
const struct parsed_proto *pp_ret;
struct parsed_proto pp_search;
{
const struct parsed_proto *pp_ret;
struct parsed_proto pp_search;
+ char *p;
if (pp_cache == NULL)
build_pp_cache(fhdr);
if (pp_cache == NULL)
build_pp_cache(fhdr);
@@
-672,6
+692,10
@@
static const struct parsed_proto *proto_parse(FILE *fhdr, const char *sym,
sym++;
strcpy(pp_search.name, sym);
sym++;
strcpy(pp_search.name, sym);
+ p = strchr(pp_search.name, '@');
+ if (p != NULL)
+ *p = 0;
+
pp_ret = bsearch(&pp_search, pp_cache, pp_cache_size,
sizeof(pp_cache[0]), pp_name_cmp);
if (pp_ret == NULL && !quiet)
pp_ret = bsearch(&pp_search, pp_cache, pp_cache_size,
sizeof(pp_cache[0]), pp_name_cmp);
if (pp_ret == NULL && !quiet)