return arch->ins_is_fused(arch, ins1, ins2);
 }
 
-static int call__parse(struct arch *arch, struct ins_operands *ops, struct map *map)
+static int call__parse(struct arch *arch, struct ins_operands *ops, struct map_symbol *ms)
 {
        char *endptr, *tok, *name;
+       struct map *map = ms->map;
        struct addr_map_symbol target = {
                .map = map,
        };
        return ins->ops == &call_ops || ins->ops == &s390_call_ops;
 }
 
-static int jump__parse(struct arch *arch __maybe_unused, struct ins_operands *ops, struct map *map __maybe_unused)
+static int jump__parse(struct arch *arch __maybe_unused, struct ins_operands *ops, struct map_symbol *ms __maybe_unused)
 {
        const char *s = strchr(ops->raw, '+');
        const char *c = strchr(ops->raw, ',');
        return 0;
 }
 
-static int lock__parse(struct arch *arch, struct ins_operands *ops, struct map *map)
+static int lock__parse(struct arch *arch, struct ins_operands *ops, struct map_symbol *ms)
 {
        ops->locked.ops = zalloc(sizeof(*ops->locked.ops));
        if (ops->locked.ops == NULL)
                goto out_free_ops;
 
        if (ops->locked.ins.ops->parse &&
-           ops->locked.ins.ops->parse(arch, ops->locked.ops, map) < 0)
+           ops->locked.ins.ops->parse(arch, ops->locked.ops, ms) < 0)
                goto out_free_ops;
 
        return 0;
        .scnprintf = lock__scnprintf,
 };
 
-static int mov__parse(struct arch *arch, struct ins_operands *ops, struct map *map __maybe_unused)
+static int mov__parse(struct arch *arch, struct ins_operands *ops, struct map_symbol *ms __maybe_unused)
 {
        char *s = strchr(ops->raw, ','), *target, *comment, prev;
 
        .scnprintf = mov__scnprintf,
 };
 
-static int dec__parse(struct arch *arch __maybe_unused, struct ins_operands *ops, struct map *map __maybe_unused)
+static int dec__parse(struct arch *arch __maybe_unused, struct ins_operands *ops, struct map_symbol *ms __maybe_unused)
 {
        char *target, *comment, *s, prev;
 
        return symbol__inc_addr_samples(he->ms.sym, he->ms.map, evidx, ip, sample);
 }
 
-static void disasm_line__init_ins(struct disasm_line *dl, struct arch *arch, struct map *map)
+static void disasm_line__init_ins(struct disasm_line *dl, struct arch *arch, struct map_symbol *ms)
 {
        dl->ins.ops = ins__find(arch, dl->ins.name);
 
        if (!dl->ins.ops)
                return;
 
-       if (dl->ins.ops->parse && dl->ins.ops->parse(arch, &dl->ops, map) < 0)
+       if (dl->ins.ops->parse && dl->ins.ops->parse(arch, &dl->ops, ms) < 0)
                dl->ins.ops = NULL;
 }
 
 struct annotate_args {
        size_t                   privsize;
        struct arch             *arch;
-       struct map              *map;
+       struct map_symbol        ms;
        struct perf_evsel       *evsel;
        s64                      offset;
        char                    *line;
                        if (disasm_line__parse(dl->al.line, &dl->ins.name, &dl->ops.raw) < 0)
                                goto out_free_line;
 
-                       disasm_line__init_ins(dl, args->arch, args->map);
+                       disasm_line__init_ins(dl, args->arch, &args->ms);
                }
        }
 
                                      struct annotate_args *args,
                                      int *line_nr)
 {
-       struct map *map = args->map;
+       struct map *map = args->ms.map;
        struct annotation *notes = symbol__annotation(sym);
        struct disasm_line *dl;
        char *line = NULL, *parsed_line, *tmp, *tmp2;
        args->offset  = offset;
        args->line    = parsed_line;
        args->line_nr = *line_nr;
+       args->ms.sym  = sym;
 
        dl = disasm_line__new(args);
        free(line);
 
 static int symbol__disassemble(struct symbol *sym, struct annotate_args *args)
 {
-       struct map *map = args->map;
+       struct map *map = args->ms.map;
        struct dso *dso = map->dso;
        char *command;
        FILE *file;
 {
        struct annotate_args args = {
                .privsize       = privsize,
-               .map            = map,
                .evsel          = evsel,
        };
        struct perf_env *env = perf_evsel__env(evsel);
                }
        }
 
+       args.ms.map = map;
+       args.ms.sym = sym;
+
        return symbol__disassemble(sym, &args);
 }