internal_linux.odin 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package runtime
  2. import "core:intrinsics"
  3. @(link_name="__umodti3")
  4. umodti3 :: proc "c" (a, b: u128) -> u128 {
  5. r: u128 = ---
  6. _ = udivmod128(a, b, &r)
  7. return r
  8. }
  9. @(link_name="__udivmodti4")
  10. udivmodti4 :: proc "c" (a, b: u128, rem: ^u128) -> u128 {
  11. return udivmod128(a, b, rem)
  12. }
  13. @(link_name="__udivti3")
  14. udivti3 :: proc "c" (a, b: u128) -> u128 {
  15. return udivmodti4(a, b, nil)
  16. }
  17. @(link_name="__modti3")
  18. modti3 :: proc "c" (a, b: i128) -> i128 {
  19. s_a := a >> (128 - 1)
  20. s_b := b >> (128 - 1)
  21. an := (a ~ s_a) - s_a
  22. bn := (b ~ s_b) - s_b
  23. r: u128 = ---
  24. _ = udivmod128(transmute(u128)an, transmute(u128)bn, &r)
  25. return (transmute(i128)r ~ s_a) - s_a
  26. }
  27. @(link_name="__divmodti4")
  28. divmodti4 :: proc "c" (a, b: i128, rem: ^i128) -> i128 {
  29. u := udivmod128(transmute(u128)a, transmute(u128)b, cast(^u128)rem)
  30. return transmute(i128)u
  31. }
  32. @(link_name="__divti3")
  33. divti3 :: proc "c" (a, b: i128) -> i128 {
  34. u := udivmodti4(transmute(u128)a, transmute(u128)b, nil)
  35. return transmute(i128)u
  36. }
  37. @(link_name="__fixdfti")
  38. fixdfti :: proc(a: u64) -> i128 {
  39. significandBits :: 52
  40. typeWidth :: (size_of(u64)*8)
  41. exponentBits :: (typeWidth - significandBits - 1)
  42. maxExponent :: ((1 << exponentBits) - 1)
  43. exponentBias :: (maxExponent >> 1)
  44. implicitBit :: (u64(1) << significandBits)
  45. significandMask :: (implicitBit - 1)
  46. signBit :: (u64(1) << (significandBits + exponentBits))
  47. absMask :: (signBit - 1)
  48. exponentMask :: (absMask ~ significandMask)
  49. // Break a into sign, exponent, significand
  50. aRep := a
  51. aAbs := aRep & absMask
  52. sign := i128(-1 if aRep & signBit != 0 else 1)
  53. exponent := u64((aAbs >> significandBits) - exponentBias)
  54. significand := u64((aAbs & significandMask) | implicitBit)
  55. // If exponent is negative, the result is zero.
  56. if exponent < 0 {
  57. return 0
  58. }
  59. // If the value is too large for the integer type, saturate.
  60. if exponent >= size_of(i128) * 8 {
  61. return max(i128) if sign == 1 else min(i128)
  62. }
  63. // If 0 <= exponent < significandBits, right shift to get the result.
  64. // Otherwise, shift left.
  65. if exponent < significandBits {
  66. return sign * i128(significand >> (significandBits - exponent))
  67. } else {
  68. return sign * (i128(significand) << (exponent - significandBits))
  69. }
  70. }