mali_mem_validation.c 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*
  2. * This confidential and proprietary software may be used only as
  3. * authorised by a licensing agreement from ARM Limited
  4. * (C) COPYRIGHT 2011-2013 ARM Limited
  5. * ALL RIGHTS RESERVED
  6. * The entire notice above must be reproduced on all authorised
  7. * copies and copies may only be made to the extent permitted
  8. * by a licensing agreement from ARM Limited.
  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. u32 phys_base; /**< Mali physical base of the memory, page aligned */
  16. u32 size; /**< size in bytes of the memory, multiple of page size */
  17. } _mali_mem_validation_t;
  18. static _mali_mem_validation_t mali_mem_validator = { MALI_INVALID_MEM_ADDR, MALI_INVALID_MEM_ADDR };
  19. _mali_osk_errcode_t mali_mem_validation_add_range(u32 start, u32 size)
  20. {
  21. /* Check that no other MEM_VALIDATION resources exist */
  22. if (MALI_INVALID_MEM_ADDR != mali_mem_validator.phys_base) {
  23. MALI_PRINT_ERROR(("Failed to add frame buffer memory; another range is already specified\n"));
  24. return _MALI_OSK_ERR_FAULT;
  25. }
  26. /* Check restrictions on page alignment */
  27. if ((0 != (start & (~_MALI_OSK_CPU_PAGE_MASK))) ||
  28. (0 != (size & (~_MALI_OSK_CPU_PAGE_MASK)))) {
  29. MALI_PRINT_ERROR(("Failed to add frame buffer memory; incorrect alignment\n"));
  30. return _MALI_OSK_ERR_FAULT;
  31. }
  32. mali_mem_validator.phys_base = start;
  33. mali_mem_validator.size = size;
  34. MALI_DEBUG_PRINT(2, ("Memory Validator installed for Mali physical address base=0x%08X, size=0x%08X\n",
  35. mali_mem_validator.phys_base, mali_mem_validator.size));
  36. return _MALI_OSK_ERR_OK;
  37. }
  38. _mali_osk_errcode_t mali_mem_validation_check(u32 phys_addr, u32 size)
  39. {
  40. if (phys_addr < (phys_addr + size)) { /* Don't allow overflow (or zero size) */
  41. if ((0 == ( phys_addr & (~_MALI_OSK_CPU_PAGE_MASK))) &&
  42. (0 == ( size & (~_MALI_OSK_CPU_PAGE_MASK)))) {
  43. if ((phys_addr >= mali_mem_validator.phys_base) &&
  44. ((phys_addr + (size - 1)) >= mali_mem_validator.phys_base) &&
  45. (phys_addr <= (mali_mem_validator.phys_base + (mali_mem_validator.size - 1))) &&
  46. ((phys_addr + (size - 1)) <= (mali_mem_validator.phys_base + (mali_mem_validator.size - 1))) ) {
  47. MALI_DEBUG_PRINT(3, ("Accepted range 0x%08X + size 0x%08X (= 0x%08X)\n", phys_addr, size, (phys_addr + size - 1)));
  48. return _MALI_OSK_ERR_OK;
  49. }
  50. }
  51. }
  52. MALI_PRINT_ERROR(("MALI PHYSICAL RANGE VALIDATION ERROR: The range supplied was: phys_base=0x%08X, size=0x%08X\n", phys_addr, size));
  53. return _MALI_OSK_ERR_FAULT;
  54. }