2013-08-20 13:35:47 +00:00
|
|
|
/*
|
|
|
|
* \brief Trace timestamp
|
|
|
|
* \author Stefan Kalkowski
|
|
|
|
* \date 2013-08-20
|
|
|
|
*
|
|
|
|
* Serialized reading of performance counter on ARM.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Genode Labs GmbH
|
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
|
|
* under the terms of the GNU General Public License version 2.
|
|
|
|
*/
|
|
|
|
|
2015-09-03 12:55:05 +00:00
|
|
|
#ifndef _INCLUDE__SPEC__ARM_V7__TRACE__TIMESTAMP_H_
|
|
|
|
#define _INCLUDE__SPEC__ARM_V7__TRACE__TIMESTAMP_H_
|
2013-08-20 13:35:47 +00:00
|
|
|
|
|
|
|
#include <base/fixed_stdint.h>
|
|
|
|
|
|
|
|
namespace Genode { namespace Trace {
|
|
|
|
|
|
|
|
typedef uint32_t Timestamp;
|
|
|
|
|
|
|
|
inline Timestamp timestamp()
|
|
|
|
{
|
|
|
|
uint32_t t;
|
|
|
|
asm volatile("mrc p15, 0, %0, c9, c13, 0" : "=r"(t));
|
|
|
|
return t;
|
|
|
|
}
|
|
|
|
} }
|
|
|
|
|
2015-09-03 12:55:05 +00:00
|
|
|
#endif /* _INCLUDE__SPEC__ARM_V7__TRACE__TIMESTAMP_H_ */
|