swap.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /* -*- tab-width: 4; -*- */
  2. /* vi: set sw=2 ts=4 expandtab: */
  3. /* $Id: 02ea6de2d8db512ca3af08f48b98ab5f6c35e7e5 $ */
  4. /*
  5. * Copyright 2010-2020 The Khronos Group Inc.
  6. * SPDX-License-Identifier: Apache-2.0
  7. */
  8. #include <KHR/khrplatform.h>
  9. #include "ktx.h"
  10. /*
  11. * SwapEndian16: Swaps endianness in an array of 16-bit values
  12. */
  13. void
  14. _ktxSwapEndian16(khronos_uint16_t* pData16, ktx_size_t count)
  15. {
  16. for (ktx_size_t i = 0; i < count; ++i)
  17. {
  18. khronos_uint16_t x = *pData16;
  19. *pData16++ = (x << 8) | (x >> 8);
  20. }
  21. }
  22. /*
  23. * SwapEndian32: Swaps endianness in an array of 32-bit values
  24. */
  25. void
  26. _ktxSwapEndian32(khronos_uint32_t* pData32, ktx_size_t count)
  27. {
  28. for (ktx_size_t i = 0; i < count; ++i)
  29. {
  30. khronos_uint32_t x = *pData32;
  31. *pData32++ = (x << 24) | ((x & 0xFF00) << 8) | ((x & 0xFF0000) >> 8) | (x >> 24);
  32. }
  33. }
  34. /*
  35. * SwapEndian364: Swaps endianness in an array of 32-bit values
  36. */
  37. void
  38. _ktxSwapEndian64(khronos_uint64_t* pData64, ktx_size_t count)
  39. {
  40. for (ktx_size_t i = 0; i < count; ++i)
  41. {
  42. khronos_uint64_t x = *pData64;
  43. *pData64++ = (x << 56) | ((x & 0xFF00) << 40) | ((x & 0xFF0000) << 24)
  44. | ((x & 0xFF000000) << 8 ) | ((x & 0xFF00000000) >> 8)
  45. | ((x & 0xFF0000000000) >> 24)
  46. | ((x & 0xFF000000000000) << 40) | (x >> 56);
  47. }
  48. }