zephyr/include/net/ptp_time.h
Stephanos Ioannidis bef377998a net: Explicitly include toolchain.h to check for endianness definitions.
This commit adds an explicit inclusion of toolchain.h from ptp_time.h.

The endianness preprocessor definitions (__BYTE_ORDER__,
__ORDER_LITTLE_ENDIAN__, __ORDER_BIG_ENDIAN__) are used by ptp_time.h;
these being not defined can easily go unnoticed and cause unexpected
behaviours, as detailed in PR #18922.

toolchain.h ensures that these preprocessor definitions are defined and
*must* be included in a file that uses these definitions.

Signed-off-by: Stephanos Ioannidis <root@stephanos.io>
2019-09-09 21:40:54 +02:00

119 lines
2.2 KiB
C

/*
* Copyright (c) 2018 Intel Corporation.
*
* SPDX-License-Identifier: Apache-2.0
*/
/**
* @file
* @brief Public functions for the Precision Time Protocol time specification.
*
*/
#ifndef ZEPHYR_INCLUDE_NET_PTP_TIME_H_
#define ZEPHYR_INCLUDE_NET_PTP_TIME_H_
/**
* @brief Precision Time Protocol time specification
* @defgroup ptp_time PTP time
* @ingroup networking
* @{
*/
#include <net/net_core.h>
#include <toolchain.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Precision Time Protocol Timestamp format.
*
* This structure represents a timestamp according
* to the Precision Time Protocol standard.
*
* Seconds are encoded as a 48 bits unsigned integer.
* Nanoseconds are encoded as a 32 bits unsigned integer.
*/
struct net_ptp_time {
/** Seconds encoded on 48 bits. */
union {
struct {
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
u32_t low;
u16_t high;
u16_t unused;
#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
u16_t unused;
u16_t high;
u32_t low;
#else
#error "Unknown byte order"
#endif
} _sec;
u64_t second;
};
/** Nanoseconds. */
u32_t nanosecond;
};
#ifdef __cplusplus
}
#endif
/**
* @brief Precision Time Protocol Extended Timestamp format.
*
* This structure represents an extended timestamp according
* to the Precision Time Protocol standard.
*
* Seconds are encoded as 48 bits unsigned integer.
* Fractional nanoseconds are encoded as 48 bits, their unit
* is 2*(-16) ns.
*/
struct net_ptp_extended_time {
/** Seconds encoded on 48 bits. */
union {
struct {
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
u32_t low;
u16_t high;
u16_t unused;
#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
u16_t unused;
u16_t high;
u32_t low;
#else
#error "Unknown byte order"
#endif
} _sec;
u64_t second;
};
/** Fractional nanoseconds on 48 bits. */
union {
struct {
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
u32_t low;
u16_t high;
u16_t unused;
#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
u16_t unused;
u16_t high;
u32_t low;
#else
#error "Unknown byte order"
#endif
} _fns;
u64_t fract_nsecond;
};
} __packed;
/**
* @}
*/
#endif /* ZEPHYR_INCLUDE_NET_PTP_TIME_H_ */