- snprintf(buf + l, sizeof(buf) - l, ")");
-
- aerr("unhandled reg call: %s\n", buf);
+
+ if (pp->argc != pp_sym->argc || pp->argc_reg != pp_sym->argc_reg)
+ bad = 1;
+ else {
+ for (i = 0; i < pp->argc; i++) {
+ if ((pp->arg[i].reg != NULL) != (pp_sym->arg[i].reg != NULL)) {
+ bad = 1;
+ break;
+ }
+ if ((pp->arg[i].reg != NULL)
+ && !IS(pp->arg[i].reg, pp_sym->arg[i].reg))
+ {
+ bad = 1;
+ break;
+ }
+ }
+ }
+
+ if (bad) {
+ pp_print(fp_sym, sizeof(fp_sym), pp_sym);
+ anote("var: %s\n", fp_var);
+ anote("sym: %s\n", fp_sym);
+ awarn("^ mismatch\n");
+ }
+
+ return pp;
+}
+
+static void output_decorated_pp(FILE *fout,
+ const struct parsed_proto *pp)
+{
+ if (pp->name[0] != '_')
+ fprintf(fout, pp->is_fastcall ? "@" : "_");
+ fprintf(fout, "%s", pp->name);
+ if (pp->is_stdcall && pp->argc > 0)
+ fprintf(fout, "@%d", pp->argc * 4);
+}
+
+static int align_value(int src_val)
+{
+ if (src_val <= 0) {
+ awarn("bad align: %d\n", src_val);
+ src_val = 1;
+ }
+ if (!g_arm_mode)
+ return src_val;
+
+ return __builtin_ffs(src_val) - 1;