"Jin, Yao" <yao.jin@xxxxxxxxxxxxxxx> writes::)
On 7/10/2017 9:46 PM, Peter Zijlstra wrote:That would be fine by me, if you're sick of talking about it and just
On Mon, Jul 10, 2017 at 08:10:50AM -0500, Segher Boessenkool wrote:Yes. It's interrupt, traps, faults. If from is in the user space and to
The "INT" thing has indeed been used as system call mechanism (typicallyPERF_BR_INT is triggered by instruction "int" .So your "PERF_BR_INT" is a system call?
PERF_BR_IRQ is triggered by interrupts, traps, faults (the ring 0,3
transition).
INT 80). But these days we have special purpose syscall instructions.
It could maybe be compared to the PPC "Unconditional TRAP with
immediate" where you use the immediate value as an index into a handler
vector.
And PERF_BR_IRQ is not an interrupt request (as its name suggests),It is actual interrupts, but also faults, traps and all the other
not what we call an "external interrupt" either; instead it is every
interrupt that is not a system call?
exceptions not caused by "INT" I think.
is in the kernel, it indicates the ring3 -> ring0 transition.
If the from instruction is not syscall or other ring transition
instruction, it should be interrupt, traps and faults. That's how we get
the PERF_BR_IRQ on x86.
Anyway, maybe we just use a minimum but the most common set of branch
types now, it could be a good start and acceptable on all architectures.
PERF_BR_COND = 1, /* conditional */
PERF_BR_UNCOND = 2, /* unconditional */
PERF_BR_IND = 3, /* indirect */
PERF_BR_CALL = 4, /* call */
PERF_BR_IND_CALL = 5, /* indirect call */
PERF_BR_RET = 6, /* return */
want to get it merged :)
I think you could expand it a bit, this list would cover the vast bulk
of branch types for us:
PERF_BR_COND /* Conditional */
PERF_BR_UNCOND /* Unconditional */
PERF_BR_IND /* Indirect */
PERF_BR_CALL /* Function call */
PERF_BR_IND_CALL /* Indirect function call */
PERF_BR_RET /* Function return */
PERF_BR_SYSCALL /* Syscall */
PERF_BR_SYSRET /* Syscall return */
PERF_BR_COND_CALL /* Conditional function call */
PERF_BR_COND_RET /* Conditional function return */
cheers