ipmid: message: fix pack/unpack compile error at aarch64 platform

After debugging with boost/multiprecision owner jzmaddock.
We have found the root cause why boost v1.79.0 got this compile error in ipmid.
More detail you can refer from https://github.com/boostorg/multiprecision/issues/472

Root cause:
Boost changed all bit counts from unsigned to std::size_t,
specifically for platforms like arm64 (and windows!) where unsigned is narrower than size_t
so that the maximum representable number isn't unnecessarily constrained.

This then changes the interface for cpp_int_backend to use size_t rather than unsigned for the bit counts.
On most platforms and most use cases, this makes no perceptible difference,
but unfortunately this appears to be one situation where it really does make a difference.

Apparently this is true even though:

template <unsigned N>
using fixed_uint_t =
    boost::multiprecision::number<boost::multiprecision::cpp_int_backend<
        N, N, boost::multiprecision::unsigned_magnitude,
        boost::multiprecision::unchecked, void>>;

Is declared with an unsigned parameter, when partially specializing for fixed_uint_t
you need to use the actual type of the template parameter in the underlying template,
not the type used in the template alias!

Solution:
Change all usage of unsigned for bitcounts to a new typedef bitcount_t
which is size_t for Boost-1.79 and later, and unsigned for Boost-1.78 and earlier.

Verified:
No compile error at aarch64 platform and test ipmitool sdr command is pass.

Signed-off-by: jzmaddock <john@johnmaddock.co.uk>
Signed-off-by: Tim Lee <timlee660101@gmail.com>
Change-Id: Id7a7c86ef854f4b9c06fc4da054c8021f76812b8
diff --git a/include/ipmid/message/pack.hpp b/include/ipmid/message/pack.hpp
index 0075000..86a12be 100644
--- a/include/ipmid/message/pack.hpp
+++ b/include/ipmid/message/pack.hpp
@@ -131,7 +131,7 @@
 
 /** @brief Specialization of PackSingle for fixed_uint_t types
  */
-template <unsigned N>
+template <bitcount_t N>
 struct PackSingle<fixed_uint_t<N>>
 {
     static int op(Payload& p, const fixed_uint_t<N>& t)
diff --git a/include/ipmid/message/types.hpp b/include/ipmid/message/types.hpp
index 7a2168e..1da2574 100644
--- a/include/ipmid/message/types.hpp
+++ b/include/ipmid/message/types.hpp
@@ -17,17 +17,24 @@
 
 #include <bitset>
 #include <boost/multiprecision/cpp_int.hpp>
+#include <boost/version.hpp>
 #include <ipmid/utility.hpp>
 #include <tuple>
 
+#if BOOST_VERSION < 107900
+using bitcount_t = unsigned;
+#else
+using bitcount_t = std::size_t;
+#endif
+
 // unsigned fixed-bit sizes
-template <unsigned N>
+template <bitcount_t N>
 using fixed_uint_t =
     boost::multiprecision::number<boost::multiprecision::cpp_int_backend<
         N, N, boost::multiprecision::unsigned_magnitude,
         boost::multiprecision::unchecked, void>>;
 // signed fixed-bit sizes
-template <unsigned N>
+template <bitcount_t N>
 using fixed_int_t =
     boost::multiprecision::number<boost::multiprecision::cpp_int_backend<
         N, N, boost::multiprecision::signed_magnitude,
@@ -79,17 +86,17 @@
 namespace details
 {
 
-template <size_t N>
+template <bitcount_t N>
 struct Size
 {
-    static constexpr size_t value = N;
+    static constexpr bitcount_t value = N;
 };
 
-template <unsigned Bits>
+template <bitcount_t Bits>
 constexpr auto getNrBits(const fixed_int_t<Bits>&) -> Size<Bits>;
-template <unsigned Bits>
+template <bitcount_t Bits>
 constexpr auto getNrBits(const fixed_uint_t<Bits>&) -> Size<Bits>;
-template <size_t Bits>
+template <bitcount_t Bits>
 constexpr auto getNrBits(const std::bitset<Bits>&) -> Size<Bits>;
 
 template <typename U>
diff --git a/include/ipmid/message/unpack.hpp b/include/ipmid/message/unpack.hpp
index 4ac4916..3a80c3f 100644
--- a/include/ipmid/message/unpack.hpp
+++ b/include/ipmid/message/unpack.hpp
@@ -157,7 +157,7 @@
 
 /** @brief Specialization of UnpackSingle for fixed_uint_t types
  */
-template <unsigned N>
+template <bitcount_t N>
 struct UnpackSingle<fixed_uint_t<N>>
 {
     static int op(Payload& p, fixed_uint_t<N>& t)