169-media-atmel-atmel-isc-add-HIS-to-register-offsets.patch 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. From 8c19aa14b8303a0e7c4bae42f3f00f9a2a65b0db Mon Sep 17 00:00:00 2001
  2. From: Eugen Hristev <[email protected]>
  3. Date: Tue, 13 Apr 2021 12:57:11 +0200
  4. Subject: [PATCH 169/247] media: atmel: atmel-isc: add HIS to register offsets
  5. The HIS submodule is a part of the atmel-isc pipeline, and stands for
  6. Histogram. This module performs a color histogram that can be read and used
  7. by the main processor.
  8. Add his to the reg offsets struct.
  9. This will allow different products to have a different reg offset for this
  10. particular module.
  11. Signed-off-by: Eugen Hristev <[email protected]>
  12. Signed-off-by: Hans Verkuil <[email protected]>
  13. Signed-off-by: Mauro Carvalho Chehab <[email protected]>
  14. ---
  15. drivers/media/platform/atmel/atmel-isc-base.c | 11 +++++++----
  16. drivers/media/platform/atmel/atmel-isc-regs.h | 2 ++
  17. drivers/media/platform/atmel/atmel-isc.h | 2 ++
  18. drivers/media/platform/atmel/atmel-sama5d2-isc.c | 1 +
  19. 4 files changed, 12 insertions(+), 4 deletions(-)
  20. --- a/drivers/media/platform/atmel/atmel-isc-base.c
  21. +++ b/drivers/media/platform/atmel/atmel-isc-base.c
  22. @@ -686,12 +686,13 @@ static void isc_set_histogram(struct isc
  23. struct isc_ctrls *ctrls = &isc->ctrls;
  24. if (enable) {
  25. - regmap_write(regmap, ISC_HIS_CFG,
  26. + regmap_write(regmap, ISC_HIS_CFG + isc->offsets.his,
  27. ISC_HIS_CFG_MODE_GR |
  28. (isc->config.sd_format->cfa_baycfg
  29. << ISC_HIS_CFG_BAYSEL_SHIFT) |
  30. ISC_HIS_CFG_RAR);
  31. - regmap_write(regmap, ISC_HIS_CTRL, ISC_HIS_CTRL_EN);
  32. + regmap_write(regmap, ISC_HIS_CTRL + isc->offsets.his,
  33. + ISC_HIS_CTRL_EN);
  34. regmap_write(regmap, ISC_INTEN, ISC_INT_HISDONE);
  35. ctrls->hist_id = ISC_HIS_CFG_MODE_GR;
  36. isc_update_profile(isc);
  37. @@ -700,7 +701,8 @@ static void isc_set_histogram(struct isc
  38. ctrls->hist_stat = HIST_ENABLED;
  39. } else {
  40. regmap_write(regmap, ISC_INTDIS, ISC_INT_HISDONE);
  41. - regmap_write(regmap, ISC_HIS_CTRL, ISC_HIS_CTRL_DIS);
  42. + regmap_write(regmap, ISC_HIS_CTRL + isc->offsets.his,
  43. + ISC_HIS_CTRL_DIS);
  44. ctrls->hist_stat = HIST_DISABLED;
  45. }
  46. @@ -1836,7 +1838,8 @@ static void isc_awb_work(struct work_str
  47. ctrls->awb = ISC_WB_NONE;
  48. }
  49. }
  50. - regmap_write(regmap, ISC_HIS_CFG, hist_id | baysel | ISC_HIS_CFG_RAR);
  51. + regmap_write(regmap, ISC_HIS_CFG + isc->offsets.his,
  52. + hist_id | baysel | ISC_HIS_CFG_RAR);
  53. isc_update_profile(isc);
  54. /* if awb has been disabled, we don't need to start another histogram */
  55. if (ctrls->awb)
  56. --- a/drivers/media/platform/atmel/atmel-isc-regs.h
  57. +++ b/drivers/media/platform/atmel/atmel-isc-regs.h
  58. @@ -224,6 +224,8 @@
  59. #define ISC_RLP_CFG_MODE_YYCC_LIMITED 0xc
  60. #define ISC_RLP_CFG_MODE_MASK GENMASK(3, 0)
  61. +/* Offset for HIS register specific to sama5d2 product */
  62. +#define ISC_SAMA5D2_HIS_OFFSET 0
  63. /* Histogram Control Register */
  64. #define ISC_HIS_CTRL 0x000003d4
  65. --- a/drivers/media/platform/atmel/atmel-isc.h
  66. +++ b/drivers/media/platform/atmel/atmel-isc.h
  67. @@ -150,6 +150,7 @@ struct isc_ctrls {
  68. * @sub422: Offset for the SUB422 register
  69. * @sub420: Offset for the SUB420 register
  70. * @rlp: Offset for the RLP register
  71. + * @his: Offset for the HIS related registers
  72. */
  73. struct isc_reg_offsets {
  74. u32 csc;
  75. @@ -157,6 +158,7 @@ struct isc_reg_offsets {
  76. u32 sub422;
  77. u32 sub420;
  78. u32 rlp;
  79. + u32 his;
  80. };
  81. /*
  82. --- a/drivers/media/platform/atmel/atmel-sama5d2-isc.c
  83. +++ b/drivers/media/platform/atmel/atmel-sama5d2-isc.c
  84. @@ -256,6 +256,7 @@ static int atmel_isc_probe(struct platfo
  85. isc->offsets.sub422 = ISC_SAMA5D2_SUB422_OFFSET;
  86. isc->offsets.sub420 = ISC_SAMA5D2_SUB420_OFFSET;
  87. isc->offsets.rlp = ISC_SAMA5D2_RLP_OFFSET;
  88. + isc->offsets.his = ISC_SAMA5D2_HIS_OFFSET;
  89. /* sama5d2-isc - 8 bits per beat */
  90. isc->dcfg = ISC_DCFG_YMBSIZE_BEATS8 | ISC_DCFG_CMBSIZE_BEATS8;