summaryrefslogtreecommitdiff
path: root/libs/endian/test/speed_test_functions.cpp
blob: 518962d0c801203cd7530e98cfe989398ba39e9b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
//  speed_test_functions.cpp  ----------------------------------------------------------//
                                                      
//  Copyright Beman Dawes 2013

//  Distributed under the Boost Software License, Version 1.0.
//  http://www.boost.org/LICENSE_1_0.txt

//--------------------------------------------------------------------------------------//

//  These functions are in a separate compilation unit partially to defeat optimizers
//  and partially to create a worst case scenario. They are in a user namespace for
//  realism.

//--------------------------------------------------------------------------------------//

#ifndef _SCL_SECURE_NO_WARNINGS
# define _SCL_SECURE_NO_WARNINGS
#endif

#ifndef _CRT_SECURE_NO_WARNINGS
# define _CRT_SECURE_NO_WARNINGS
#endif

#include "speed_test_functions.hpp"

namespace user
{

  int16_t return_x_big_int16(int16_t x, big_int16_t) BOOST_NOEXCEPT { return x; }
  int16_t return_x_little_int16(int16_t x, little_int16_t) BOOST_NOEXCEPT { return x; }
  int16_t return_x_value_big_int16(int16_t x, big_int16_t) BOOST_NOEXCEPT
  {
    return conditional_reverse<order::native, order::big>(x);
  }
  int16_t return_x_value_little_int16(int16_t x, little_int16_t) BOOST_NOEXCEPT
  {
    return conditional_reverse<order::native, order::little>(x);
  }
  int16_t return_x_inplace_big_int16(int16_t x, big_int16_t) BOOST_NOEXCEPT
  {
    conditional_reverse_inplace<order::native, order::big>(x); return x;
  }
  int16_t return_x_inplace_little_int16(int16_t x, little_int16_t) BOOST_NOEXCEPT
  {
    conditional_reverse_inplace<order::native, order::little>(x); return x;
  }
  int16_t return_y_big_int16(int16_t x, big_int16_t y) BOOST_NOEXCEPT { return y; }
  int16_t return_y_little_int16(int16_t x, little_int16_t y) BOOST_NOEXCEPT { return y; }

  //------------------------------------------------------------------------------------//

  int32_t return_x_big_int32(int32_t x, big_int32_t) BOOST_NOEXCEPT { return x; }
  int32_t return_x_little_int32(int32_t x, little_int32_t) BOOST_NOEXCEPT { return x; }
  int32_t return_x_value_big_int32(int32_t x, big_int32_t) BOOST_NOEXCEPT
  {
    return conditional_reverse<order::native, order::big>(x);
  }
  int32_t return_x_value_little_int32(int32_t x, little_int32_t) BOOST_NOEXCEPT
  {
    return conditional_reverse<order::native, order::little>(x);
  }
  int32_t return_x_inplace_big_int32(int32_t x, big_int32_t) BOOST_NOEXCEPT
  {
    conditional_reverse_inplace<order::native, order::big>(x); return x;
  }
  int32_t return_x_inplace_little_int32(int32_t x, little_int32_t) BOOST_NOEXCEPT
  {
    conditional_reverse_inplace<order::native, order::little>(x); return x;
  }
  int32_t return_y_big_int32(int32_t x, big_int32_t y) BOOST_NOEXCEPT { return y; }
  int32_t return_y_little_int32(int32_t x, little_int32_t y) BOOST_NOEXCEPT { return y; }

  //------------------------------------------------------------------------------------//

  int64_t return_x_big_int64(int64_t x, big_int64_t) BOOST_NOEXCEPT { return x; }
  int64_t return_x_little_int64(int64_t x, little_int64_t) BOOST_NOEXCEPT { return x; }
  int64_t return_x_value_big_int64(int64_t x, big_int64_t) BOOST_NOEXCEPT
  {
    return conditional_reverse<order::native, order::big>(x);
  }
  int64_t return_x_value_little_int64(int64_t x, little_int64_t) BOOST_NOEXCEPT
  {
    return conditional_reverse<order::native, order::little>(x);
  }
  int64_t return_x_inplace_big_int64(int64_t x, big_int64_t) BOOST_NOEXCEPT
  {
    conditional_reverse_inplace<order::native, order::big>(x); return x;
  }
  int64_t return_x_inplace_little_int64(int64_t x, little_int64_t) BOOST_NOEXCEPT
  {
    conditional_reverse_inplace<order::native, order::little>(x); return x;
  }
  int64_t return_y_big_int64(int64_t x, big_int64_t y) BOOST_NOEXCEPT { return y; }
  int64_t return_y_little_int64(int64_t x, little_int64_t y) BOOST_NOEXCEPT { return y; }

}