1

I have some rather complex and highly templated code (C++, but this may not be very relevant) of which I'd like to know the number of adds, subs, muls, divs, and sqrts at execution. Is there an automatic way to get this information (the compiler could work it out easily)? I tried to count it myself in the assembler code generated, but got confused with jp, jmp, and calls.

Walter
  • 44,150
  • 20
  • 113
  • 196

2 Answers2

1

I would suggest to override +, -, *, / operators and sqrt function for some float-like type, in which you can count their use.

Something like this:

struct Double {
    double val;
    Double(double v): val(v) {}
    static unsigned add_count = 0;
    Double operator+(Double other) {
        ++add_count;
        return Double(val + other.val);
    }
};

do_your_stuff<Double>();
Maciek D.
  • 2,754
  • 1
  • 20
  • 17
  • If do_your_stuff calls any external function, say `sqrt`, this won't work since `sqrt` can't handle this class. – fheshwfq Nov 28 '13 at 22:04
  • You can overload `sqrt` or any other function as well in this manner. But of course this approach only makes sense if you know what `do_your_stuff` calls. – Maciek D. Nov 29 '13 at 18:48
0

Yes you can, but the way is a bit complex:

Try to change your "add", "sub", "mul", "div", "sqrt" in the binary to some invalid opcode. Dont forget to define an invalid opcode error handler to restore the opcode. When you program runs, the cpu will trigger the invalid opcode error at those changed "add", "sub", "mul", "div", "sqrt". By counting the times invalid opcode error being triggered, you can get the exactly what you want.

user2760751
  • 343
  • 2
  • 4
  • This would work if the state of the system is recoverable from an opcode error. Also, your method changes the functionality; so that without one of those opcodes, the program may run more iterations or less. – Thomas Matthews Sep 10 '13 at 19:48
  • huuh. This is serious hacking ... I rather have a less interfering approach. Also, how would I do this in practice *Try to change your "add", "sub", "mul", "div", "sqrt" in the binary to some invalid opcode.* ?? – Walter Sep 10 '13 at 20:55