block_header.c 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*
  2. * Copyright 2011 Institute of Communication and Computer Systems (ICCS)
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. *
  16. */
  17. #include "block_header.h"
  18. block_header_t * get_header(void *ptr) {
  19. return (block_header_t *) ((char *) ptr - HEADER_SIZE);
  20. }
  21. size_t get_size(void *ptr) {
  22. return get_header(ptr)->size >> 1;
  23. }
  24. #ifdef FUTURE_FEATURES
  25. size_t get_requested_size(void *ptr) {
  26. return get_header(ptr)->requested_size;
  27. }
  28. #endif /* FUTURE_FEATURES */
  29. size_t get_size_availability(void *ptr) {
  30. return get_header(ptr)->size;
  31. }
  32. void set_size_and_free(void *ptr, size_t size) {
  33. get_header(ptr)->size = size << 1;
  34. }
  35. void set_size_and_used(void *ptr, size_t size) {
  36. block_header_t *header = get_header(ptr);
  37. header->size = size << 1;
  38. header->size |= 1;
  39. }
  40. #ifdef FUTURE_FEATURES
  41. void set_requested_size(void *ptr, size_t size) {
  42. get_header(ptr)->requested_size = size;
  43. }
  44. #endif /* FUTURE_FEATURES */
  45. void mark_used(void *ptr) {
  46. get_header(ptr)->size |= 1;
  47. }
  48. void mark_free(void *ptr) {
  49. get_header(ptr)->size &= (~ 0x1);
  50. }
  51. #ifdef WITH_OWNERSHIP
  52. void set_owner(void *ptr, heap_t *heap_owner) {
  53. get_header(ptr)->heap_owner = heap_owner;
  54. }
  55. heap_t * get_owner(void *ptr) {
  56. return get_header(ptr)->heap_owner;
  57. }
  58. #endif /* WITH_OWNERSHIP */
  59. bool is_previous_free(void *ptr) {
  60. if (get_header(ptr)->previous_size & (size_t) 1) {
  61. return false;
  62. } else {
  63. return true;
  64. }
  65. }
  66. void set_previous_size_availability(void *ptr, size_t previous_size_availability) {
  67. get_header(ptr)->previous_size = previous_size_availability;
  68. }
  69. size_t get_previous_size(void *ptr) {
  70. return get_header(ptr)->previous_size >> 1;
  71. }
  72. size_t get_previous_size_availability(void *ptr) {
  73. return get_header(ptr)->previous_size;
  74. }
  75. void * get_dlprevious(void *ptr) {
  76. return (void *) ((char *) ptr - HEADER_SIZE - get_previous_size(ptr));
  77. }