solo6x10-offsets.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /*
  3. * Copyright (C) 2010-2013 Bluecherry, LLC <https://www.bluecherrydvr.com>
  4. *
  5. * Original author:
  6. * Ben Collins <[email protected]>
  7. *
  8. * Additional work by:
  9. * John Brooks <[email protected]>
  10. */
  11. #ifndef __SOLO6X10_OFFSETS_H
  12. #define __SOLO6X10_OFFSETS_H
  13. #define SOLO_DISP_EXT_ADDR 0x00000000
  14. #define SOLO_DISP_EXT_SIZE 0x00480000
  15. #define SOLO_EOSD_EXT_ADDR \
  16. (SOLO_DISP_EXT_ADDR + SOLO_DISP_EXT_SIZE)
  17. #define SOLO_EOSD_EXT_SIZE(__solo) \
  18. (__solo->type == SOLO_DEV_6010 ? 0x10000 : 0x20000)
  19. #define SOLO_EOSD_EXT_SIZE_MAX 0x20000
  20. #define SOLO_EOSD_EXT_AREA(__solo) \
  21. (SOLO_EOSD_EXT_SIZE(__solo) * 32)
  22. #define SOLO_EOSD_EXT_ADDR_CHAN(__solo, ch) \
  23. (SOLO_EOSD_EXT_ADDR + SOLO_EOSD_EXT_SIZE(__solo) * (ch))
  24. #define SOLO_MOTION_EXT_ADDR(__solo) \
  25. (SOLO_EOSD_EXT_ADDR + SOLO_EOSD_EXT_AREA(__solo))
  26. #define SOLO_MOTION_EXT_SIZE 0x00080000
  27. #define SOLO_G723_EXT_ADDR(__solo) \
  28. (SOLO_MOTION_EXT_ADDR(__solo) + SOLO_MOTION_EXT_SIZE)
  29. #define SOLO_G723_EXT_SIZE 0x00010000
  30. #define SOLO_CAP_EXT_ADDR(__solo) \
  31. (SOLO_G723_EXT_ADDR(__solo) + SOLO_G723_EXT_SIZE)
  32. /* 18 is the maximum number of pages required for PAL@D1, the largest frame
  33. * possible */
  34. #define SOLO_CAP_PAGE_SIZE (18 << 16)
  35. /* Always allow the encoder enough for 16 channels, even if we have less. The
  36. * exception is if we have card with only 32Megs of memory. */
  37. #define SOLO_CAP_EXT_SIZE(__solo) \
  38. ((((__solo->sdram_size <= (32 << 20)) ? 4 : 16) + 1) \
  39. * SOLO_CAP_PAGE_SIZE)
  40. #define SOLO_EREF_EXT_ADDR(__solo) \
  41. (SOLO_CAP_EXT_ADDR(__solo) + SOLO_CAP_EXT_SIZE(__solo))
  42. #define SOLO_EREF_EXT_SIZE 0x00140000
  43. #define SOLO_EREF_EXT_AREA(__solo) \
  44. (SOLO_EREF_EXT_SIZE * __solo->nr_chans * 2)
  45. #define __SOLO_JPEG_MIN_SIZE(__solo) (__solo->nr_chans * 0x00080000)
  46. #define SOLO_MP4E_EXT_ADDR(__solo) \
  47. (SOLO_EREF_EXT_ADDR(__solo) + SOLO_EREF_EXT_AREA(__solo))
  48. #define SOLO_MP4E_EXT_SIZE(__solo) \
  49. max((__solo->nr_chans * 0x00080000), \
  50. min(((__solo->sdram_size - SOLO_MP4E_EXT_ADDR(__solo)) - \
  51. __SOLO_JPEG_MIN_SIZE(__solo)), 0x00ff0000))
  52. #define __SOLO_JPEG_MIN_SIZE(__solo) (__solo->nr_chans * 0x00080000)
  53. #define SOLO_JPEG_EXT_ADDR(__solo) \
  54. (SOLO_MP4E_EXT_ADDR(__solo) + SOLO_MP4E_EXT_SIZE(__solo))
  55. #define SOLO_JPEG_EXT_SIZE(__solo) \
  56. max(__SOLO_JPEG_MIN_SIZE(__solo), \
  57. min((__solo->sdram_size - SOLO_JPEG_EXT_ADDR(__solo)), 0x00ff0000))
  58. #define SOLO_SDRAM_END(__solo) \
  59. (SOLO_JPEG_EXT_ADDR(__solo) + SOLO_JPEG_EXT_SIZE(__solo))
  60. #endif /* __SOLO6X10_OFFSETS_H */