logicvc_regs.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright (C) 2019-2022 Bootlin
  4. * Author: Paul Kocialkowski <[email protected]>
  5. *
  6. * Copyright (C) 2014 Xylon d.o.o.
  7. * Author: Davor Joja <[email protected]>
  8. */
  9. #ifndef _LOGICVC_REGS_H_
  10. #define _LOGICVC_REGS_H_
  11. #define LOGICVC_DIMENSIONS_MAX (BIT(16) - 1)
  12. #define LOGICVC_HSYNC_FRONT_PORCH_REG 0x00
  13. #define LOGICVC_HSYNC_REG 0x08
  14. #define LOGICVC_HSYNC_BACK_PORCH_REG 0x10
  15. #define LOGICVC_HRES_REG 0x18
  16. #define LOGICVC_VSYNC_FRONT_PORCH_REG 0x20
  17. #define LOGICVC_VSYNC_REG 0x28
  18. #define LOGICVC_VSYNC_BACK_PORCH_REG 0x30
  19. #define LOGICVC_VRES_REG 0x38
  20. #define LOGICVC_CTRL_REG 0x40
  21. #define LOGICVC_CTRL_CLOCK_INVERT BIT(8)
  22. #define LOGICVC_CTRL_PIXEL_INVERT BIT(7)
  23. #define LOGICVC_CTRL_DE_INVERT BIT(5)
  24. #define LOGICVC_CTRL_DE_ENABLE BIT(4)
  25. #define LOGICVC_CTRL_VSYNC_INVERT BIT(3)
  26. #define LOGICVC_CTRL_VSYNC_ENABLE BIT(2)
  27. #define LOGICVC_CTRL_HSYNC_INVERT BIT(1)
  28. #define LOGICVC_CTRL_HSYNC_ENABLE BIT(0)
  29. #define LOGICVC_DTYPE_REG 0x48
  30. #define LOGICVC_BACKGROUND_COLOR_REG 0x50
  31. #define LOGICVC_BUFFER_SEL_REG 0x58
  32. #define LOGICVC_BUFFER_SEL_VALUE(i, v) \
  33. (BIT(10 + (i)) | ((v) << (2 * (i))))
  34. #define LOGICVC_BUFFER_SEL_MAX 2
  35. #define LOGICVC_DOUBLE_CLUT_REG 0x60
  36. #define LOGICVC_INT_STAT_REG 0x68
  37. #define LOGICVC_INT_STAT_V_SYNC BIT(5)
  38. #define LOGICVC_INT_MASK_REG 0x70
  39. #define LOGICVC_INT_MASK_V_SYNC BIT(5)
  40. #define LOGICVC_POWER_CTRL_REG 0x78
  41. #define LOGICVC_POWER_CTRL_BACKLIGHT_ENABLE BIT(0)
  42. #define LOGICVC_POWER_CTRL_VDD_ENABLE BIT(1)
  43. #define LOGICVC_POWER_CTRL_VEE_ENABLE BIT(2)
  44. #define LOGICVC_POWER_CTRL_VIDEO_ENABLE BIT(3)
  45. #define LOGICVC_IP_VERSION_REG 0xf8
  46. #define LOGICVC_IP_VERSION_MAJOR_MASK GENMASK(16, 11)
  47. #define LOGICVC_IP_VERSION_MINOR_MASK GENMASK(10, 5)
  48. #define LOGICVC_IP_VERSION_LEVEL_MASK GENMASK(4, 0)
  49. #define LOGICVC_LAYER_ADDRESS_REG(i) (0x100 + (i) * 0x80)
  50. #define LOGICVC_LAYER_HOFFSET_REG(i) (0x100 + (i) * 0x80)
  51. #define LOGICVC_LAYER_VOFFSET_REG(i) (0x108 + (i) * 0x80)
  52. #define LOGICVC_LAYER_VOFFSET_MAX 4095
  53. #define LOGICVC_LAYER_HPOSITION_REG(i) (0x110 + (i) * 0x80)
  54. #define LOGICVC_LAYER_VPOSITION_REG(i) (0x118 + (i) * 0x80)
  55. #define LOGICVC_LAYER_WIDTH_REG(i) (0x120 + (i) * 0x80)
  56. #define LOGICVC_LAYER_HEIGHT_REG(i) (0x128 + (i) * 0x80)
  57. #define LOGICVC_LAYER_ALPHA_REG(i) (0x130 + (i) * 0x80)
  58. #define LOGICVC_LAYER_CTRL_REG(i) (0x138 + (i) * 0x80)
  59. #define LOGICVC_LAYER_CTRL_ENABLE BIT(0)
  60. #define LOGICVC_LAYER_CTRL_COLOR_KEY_DISABLE BIT(1)
  61. #define LOGICVC_LAYER_CTRL_PIXEL_FORMAT_INVERT BIT(4)
  62. #define LOGICVC_LAYER_COLOR_KEY_REG(i) (0x140 + (i) * 0x80)
  63. #endif