2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief Convert between host endianess and big endian.
|
|
|
|
* \author Stebastian Sumpf
|
|
|
|
* \author Stefan Kalkowski
|
|
|
|
* \date 2010-08-04
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2010-2017 Genode Labs GmbH
|
2011-12-22 16:19:25 +01:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 13:23:52 +01:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2011-12-22 16:19:25 +01:00
|
|
|
*/
|
|
|
|
#ifndef _UTIL__ENDIAN_H_
|
|
|
|
#define _UTIL__ENDIAN_H_
|
|
|
|
|
|
|
|
#include <base/stdint.h>
|
|
|
|
|
|
|
|
template <typename T>
|
2015-04-29 11:36:54 +02:00
|
|
|
inline T host_to_big_endian(T x)
|
2011-12-22 16:19:25 +01:00
|
|
|
{
|
|
|
|
Genode::uint8_t v[sizeof(T)];
|
2021-12-02 11:23:38 +01:00
|
|
|
|
|
|
|
for (unsigned i = 0; i < sizeof(T); i++) {
|
|
|
|
|
|
|
|
unsigned const shift = ((unsigned)sizeof(T) - i - 1) * 8;
|
|
|
|
|
|
|
|
v[i] = (Genode::uint8_t)((x & (0xffu << shift)) >> shift);
|
2011-12-22 16:19:25 +01:00
|
|
|
}
|
|
|
|
return *(T *)v;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _UTIL__ENDIAN_H_ */
|