diff --git a/eeschema/sch_plugins/altium/altium_parser_sch.cpp b/eeschema/sch_plugins/altium/altium_parser_sch.cpp
index 2978608cfb..bac7716792 100644
--- a/eeschema/sch_plugins/altium/altium_parser_sch.cpp
+++ b/eeschema/sch_plugins/altium/altium_parser_sch.cpp
@@ -43,7 +43,12 @@ ALTIUM_SCH_RECORD ReadRecord( const std::map& aProps )
constexpr int Altium2KiCadUnit( const int val, const int frac )
{
- return Mils2iu( val ) * 10 + Mils2iu( frac ) / 10000; // TODO: correct, rounding issues?
+ constexpr double int_limit = ( std::numeric_limits::max() - 10 ) / 2.54;
+
+ double dbase = 10 * Mils2iu( val );
+ double dfrac = Mils2iu( frac ) / 10000.0;
+
+ return KiROUND( Clamp( -int_limit, ( dbase + dfrac ) / 10.0, int_limit ) ) * 10;
}
diff --git a/libs/kimath/include/math/util.h b/libs/kimath/include/math/util.h
index c9407c2086..d6e9fab913 100644
--- a/libs/kimath/include/math/util.h
+++ b/libs/kimath/include/math/util.h
@@ -49,7 +49,7 @@ void kimathLogDebug( const char* aFormatString, ... );
* result is: lower <= value <= upper
*
*/
-template inline const T& Clamp( const T& lower, const T& value, const T& upper )
+template inline constexpr T Clamp( const T& lower, const T& value, const T& upper )
{
if( value < lower )
return lower;