/drivers/gpu/mali/mali/common/mali_mem_validation.c

https://bitbucket.org/ndreys/linux-sunxi · C · 71 lines · 49 code · 11 blank · 11 comment · 10 complexity · a47c85f479bcd52c5d62403ce57a53d6 MD5 · raw file

  1. /*
  2. * Copyright (C) 2011-2012 ARM Limited. All rights reserved.
  3. *
  4. * This program is free software and is provided to you under the terms of the GNU General Public License version 2
  5. * as published by the Free Software Foundation, and any use by you of this program is subject to the terms of such GNU licence.
  6. *
  7. * A copy of the licence is included with the program, and can also be obtained from Free Software
  8. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  9. */
  10. #include "mali_mem_validation.h"
  11. #include "mali_osk.h"
  12. #include "mali_kernel_common.h"
  13. #define MALI_INVALID_MEM_ADDR 0xFFFFFFFF
  14. typedef struct
  15. {
  16. u32 phys_base; /**< Mali physical base of the memory, page aligned */
  17. u32 size; /**< size in bytes of the memory, multiple of page size */
  18. } _mali_mem_validation_t;
  19. static _mali_mem_validation_t mali_mem_validator = { MALI_INVALID_MEM_ADDR, MALI_INVALID_MEM_ADDR };
  20. _mali_osk_errcode_t mali_mem_validation_add_range(const _mali_osk_resource_t *resource)
  21. {
  22. /* Check that no other MEM_VALIDATION resources exist */
  23. if (MALI_INVALID_MEM_ADDR != mali_mem_validator.phys_base)
  24. {
  25. MALI_PRINT_ERROR(("Failed to add MEM_VALIDATION resource %s; another range is already specified\n", resource->description));
  26. return _MALI_OSK_ERR_FAULT;
  27. }
  28. /* Check restrictions on page alignment */
  29. if ((0 != (resource->base & (~_MALI_OSK_CPU_PAGE_MASK))) ||
  30. (0 != (resource->size & (~_MALI_OSK_CPU_PAGE_MASK))))
  31. {
  32. MALI_PRINT_ERROR(("Failed to add MEM_VALIDATION resource %s; incorrect alignment\n", resource->description));
  33. return _MALI_OSK_ERR_FAULT;
  34. }
  35. mali_mem_validator.phys_base = resource->base;
  36. mali_mem_validator.size = resource->size;
  37. MALI_DEBUG_PRINT(2, ("Memory Validator '%s' installed for Mali physical address base=0x%08X, size=0x%08X\n",
  38. resource->description, mali_mem_validator.phys_base, mali_mem_validator.size));
  39. return _MALI_OSK_ERR_OK;
  40. }
  41. _mali_osk_errcode_t mali_mem_validation_check(u32 phys_addr, u32 size)
  42. {
  43. if (phys_addr < (phys_addr + size)) /* Don't allow overflow (or zero size) */
  44. {
  45. if ((0 == ( phys_addr & (~_MALI_OSK_CPU_PAGE_MASK))) &&
  46. (0 == ( size & (~_MALI_OSK_CPU_PAGE_MASK))))
  47. {
  48. if ((phys_addr >= mali_mem_validator.phys_base) &&
  49. ((phys_addr + (size - 1)) >= mali_mem_validator.phys_base) &&
  50. (phys_addr <= (mali_mem_validator.phys_base + (mali_mem_validator.size - 1))) &&
  51. ((phys_addr + (size - 1)) <= (mali_mem_validator.phys_base + (mali_mem_validator.size - 1))) )
  52. {
  53. MALI_DEBUG_PRINT(3, ("Accepted range 0x%08X + size 0x%08X (= 0x%08X)\n", phys_addr, size, (phys_addr + size - 1)));
  54. return _MALI_OSK_ERR_OK;
  55. }
  56. }
  57. }
  58. MALI_PRINT_ERROR(("MALI PHYSICAL RANGE VALIDATION ERROR: The range supplied was: phys_base=0x%08X, size=0x%08X\n", phys_addr, size));
  59. return _MALI_OSK_ERR_FAULT;
  60. }