procs.odin 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package runtime
  2. when ODIN_NO_CRT && ODIN_OS == .Windows {
  3. foreign import lib "system:NtDll.lib"
  4. @(private="file")
  5. @(default_calling_convention="stdcall")
  6. foreign lib {
  7. RtlMoveMemory :: proc(dst, s: rawptr, length: int) ---
  8. RtlFillMemory :: proc(dst: rawptr, length: int, fill: i32) ---
  9. }
  10. @(link_name="memset", linkage="strong", require)
  11. memset :: proc "c" (ptr: rawptr, val: i32, len: int) -> rawptr {
  12. RtlFillMemory(ptr, len, val)
  13. return ptr
  14. }
  15. @(link_name="memmove", linkage="strong", require)
  16. memmove :: proc "c" (dst, src: rawptr, len: int) -> rawptr {
  17. RtlMoveMemory(dst, src, len)
  18. return dst
  19. }
  20. @(link_name="memcpy", linkage="strong", require)
  21. memcpy :: proc "c" (dst, src: rawptr, len: int) -> rawptr {
  22. RtlMoveMemory(dst, src, len)
  23. return dst
  24. }
  25. } else when ODIN_NO_CRT || (ODIN_ARCH == .wasm32 || ODIN_ARCH == .wasm64p32) {
  26. @(link_name="memset", linkage="strong", require)
  27. memset :: proc "c" (ptr: rawptr, val: i32, len: int) -> rawptr {
  28. if ptr != nil && len != 0 {
  29. b := byte(val)
  30. p := ([^]byte)(ptr)
  31. for i := 0; i < len; i += 1 {
  32. p[i] = b
  33. }
  34. }
  35. return ptr
  36. }
  37. @(link_name="bzero", linkage="strong", require)
  38. bzero :: proc "c" (ptr: rawptr, len: int) -> rawptr {
  39. if ptr != nil && len != 0 {
  40. p := ([^]byte)(ptr)
  41. for i := 0; i < len; i += 1 {
  42. p[i] = 0
  43. }
  44. }
  45. return ptr
  46. }
  47. @(link_name="memmove", linkage="strong", require)
  48. memmove :: proc "c" (dst, src: rawptr, len: int) -> rawptr {
  49. d, s := ([^]byte)(dst), ([^]byte)(src)
  50. if d == s || len == 0 {
  51. return dst
  52. }
  53. if d > s && uintptr(d)-uintptr(s) < uintptr(len) {
  54. for i := len-1; i >= 0; i -= 1 {
  55. d[i] = s[i]
  56. }
  57. return dst
  58. }
  59. if s > d && uintptr(s)-uintptr(d) < uintptr(len) {
  60. for i := 0; i < len; i += 1 {
  61. d[i] = s[i]
  62. }
  63. return dst
  64. }
  65. return memcpy(dst, src, len)
  66. }
  67. @(link_name="memcpy", linkage="strong", require)
  68. memcpy :: proc "c" (dst, src: rawptr, len: int) -> rawptr {
  69. d, s := ([^]byte)(dst), ([^]byte)(src)
  70. if d != s {
  71. for i := 0; i < len; i += 1 {
  72. d[i] = s[i]
  73. }
  74. }
  75. return d
  76. }
  77. } else {
  78. memset :: proc "c" (ptr: rawptr, val: i32, len: int) -> rawptr {
  79. if ptr != nil && len != 0 {
  80. b := byte(val)
  81. p := ([^]byte)(ptr)
  82. for i := 0; i < len; i += 1 {
  83. p[i] = b
  84. }
  85. }
  86. return ptr
  87. }
  88. }