mirror of https://github.com/ipxe/ipxe.git
29 lines
460 B
C
29 lines
460 B
C
#ifndef _BITS_PROFILE_H
|
|
#define _BITS_PROFILE_H
|
|
|
|
/** @file
|
|
*
|
|
* Profiling
|
|
*
|
|
*/
|
|
|
|
FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
|
|
|
|
#include <stdint.h>
|
|
|
|
/**
|
|
* Get profiling timestamp
|
|
*
|
|
* @ret timestamp Timestamp
|
|
*/
|
|
static inline __attribute__ (( always_inline )) uint64_t
|
|
profile_timestamp ( void ) {
|
|
uint64_t cycles;
|
|
|
|
/* Read cycle counter */
|
|
__asm__ __volatile__ ( "rdtime.d %0, $zero\n\t" : "=r" ( cycles ) );
|
|
return cycles;
|
|
}
|
|
|
|
#endif /* _BITS_PROFILE_H */
|