#ifndef _BITS_PROFILE_H #define _BITS_PROFILE_H /** @file * * Profiling * */ FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL ); #include extern uint32_t pmccntr_status; /** * Get profiling timestamp * * @ret timestamp Timestamp */ static inline __attribute__ (( always_inline )) unsigned long profile_timestamp ( void ) { uint32_t cycles; /* Read cycle counter */ __asm__ __volatile__ ( /* Check PMCCNTR status */ "tst %0, %0\n\t" /* Check availability if not yet known */ "it mi\n\t" "blxmi pmccntr_check\n\t" /* Read PMCCNTR if available */ "it ne\n\t" "mrcne p15, 0, %0, c9, c13, 0\n\t" "\n1:\n\t" : "=r" ( cycles ) : "0" ( pmccntr_status ) : "cc", "lr" ); return cycles; } #endif /* _BITS_PROFILE_H */