xref: /openbmc/linux/drivers/media/platform/qcom/camss/camss.c (revision 2f49e05d6b58d660f035a75ff96b77071b4bd5ed)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * camss.c
4  *
5  * Qualcomm MSM Camera Subsystem - Core
6  *
7  * Copyright (c) 2015, The Linux Foundation. All rights reserved.
8  * Copyright (C) 2015-2018 Linaro Ltd.
9  */
10 #include <linux/clk.h>
11 #include <linux/interconnect.h>
12 #include <linux/media-bus-format.h>
13 #include <linux/media.h>
14 #include <linux/module.h>
15 #include <linux/platform_device.h>
16 #include <linux/of.h>
17 #include <linux/of_graph.h>
18 #include <linux/pm_runtime.h>
19 #include <linux/pm_domain.h>
20 #include <linux/slab.h>
21 #include <linux/videodev2.h>
22 
23 #include <media/media-device.h>
24 #include <media/v4l2-async.h>
25 #include <media/v4l2-device.h>
26 #include <media/v4l2-mc.h>
27 #include <media/v4l2-fwnode.h>
28 
29 #include "camss.h"
30 
31 #define CAMSS_CLOCK_MARGIN_NUMERATOR 105
32 #define CAMSS_CLOCK_MARGIN_DENOMINATOR 100
33 
34 static const struct resources csiphy_res_8x16[] = {
35 	/* CSIPHY0 */
36 	{
37 		.regulators = {},
38 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy0_timer" },
39 		.clock_rate = { { 0 },
40 				{ 0 },
41 				{ 0 },
42 				{ 100000000, 200000000 } },
43 		.reg = { "csiphy0", "csiphy0_clk_mux" },
44 		.interrupt = { "csiphy0" }
45 	},
46 
47 	/* CSIPHY1 */
48 	{
49 		.regulators = {},
50 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy1_timer" },
51 		.clock_rate = { { 0 },
52 				{ 0 },
53 				{ 0 },
54 				{ 100000000, 200000000 } },
55 		.reg = { "csiphy1", "csiphy1_clk_mux" },
56 		.interrupt = { "csiphy1" }
57 	}
58 };
59 
60 static const struct resources csid_res_8x16[] = {
61 	/* CSID0 */
62 	{
63 		.regulators = { "vdda" },
64 		.clock = { "top_ahb", "ispif_ahb", "csi0_ahb", "ahb",
65 			   "csi0", "csi0_phy", "csi0_pix", "csi0_rdi" },
66 		.clock_rate = { { 0 },
67 				{ 0 },
68 				{ 0 },
69 				{ 0 },
70 				{ 100000000, 200000000 },
71 				{ 0 },
72 				{ 0 },
73 				{ 0 } },
74 		.reg = { "csid0" },
75 		.interrupt = { "csid0" }
76 	},
77 
78 	/* CSID1 */
79 	{
80 		.regulators = { "vdda" },
81 		.clock = { "top_ahb", "ispif_ahb", "csi1_ahb", "ahb",
82 			   "csi1", "csi1_phy", "csi1_pix", "csi1_rdi" },
83 		.clock_rate = { { 0 },
84 				{ 0 },
85 				{ 0 },
86 				{ 0 },
87 				{ 100000000, 200000000 },
88 				{ 0 },
89 				{ 0 },
90 				{ 0 } },
91 		.reg = { "csid1" },
92 		.interrupt = { "csid1" }
93 	},
94 };
95 
96 static const struct resources_ispif ispif_res_8x16 = {
97 	/* ISPIF */
98 	.clock = { "top_ahb", "ahb", "ispif_ahb",
99 		   "csi0", "csi0_pix", "csi0_rdi",
100 		   "csi1", "csi1_pix", "csi1_rdi" },
101 	.clock_for_reset = { "vfe0", "csi_vfe0" },
102 	.reg = { "ispif", "csi_clk_mux" },
103 	.interrupt = "ispif"
104 
105 };
106 
107 static const struct resources vfe_res_8x16[] = {
108 	/* VFE0 */
109 	{
110 		.regulators = {},
111 		.clock = { "top_ahb", "vfe0", "csi_vfe0",
112 			   "vfe_ahb", "vfe_axi", "ahb" },
113 		.clock_rate = { { 0 },
114 				{ 50000000, 80000000, 100000000, 160000000,
115 				  177780000, 200000000, 266670000, 320000000,
116 				  400000000, 465000000 },
117 				{ 0 },
118 				{ 0 },
119 				{ 0 },
120 				{ 0 },
121 				{ 0 },
122 				{ 0 },
123 				{ 0 } },
124 		.reg = { "vfe0" },
125 		.interrupt = { "vfe0" }
126 	}
127 };
128 
129 static const struct resources csiphy_res_8x96[] = {
130 	/* CSIPHY0 */
131 	{
132 		.regulators = {},
133 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy0_timer" },
134 		.clock_rate = { { 0 },
135 				{ 0 },
136 				{ 0 },
137 				{ 100000000, 200000000, 266666667 } },
138 		.reg = { "csiphy0", "csiphy0_clk_mux" },
139 		.interrupt = { "csiphy0" }
140 	},
141 
142 	/* CSIPHY1 */
143 	{
144 		.regulators = {},
145 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy1_timer" },
146 		.clock_rate = { { 0 },
147 				{ 0 },
148 				{ 0 },
149 				{ 100000000, 200000000, 266666667 } },
150 		.reg = { "csiphy1", "csiphy1_clk_mux" },
151 		.interrupt = { "csiphy1" }
152 	},
153 
154 	/* CSIPHY2 */
155 	{
156 		.regulators = {},
157 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy2_timer" },
158 		.clock_rate = { { 0 },
159 				{ 0 },
160 				{ 0 },
161 				{ 100000000, 200000000, 266666667 } },
162 		.reg = { "csiphy2", "csiphy2_clk_mux" },
163 		.interrupt = { "csiphy2" }
164 	}
165 };
166 
167 static const struct resources csid_res_8x96[] = {
168 	/* CSID0 */
169 	{
170 		.regulators = { "vdda" },
171 		.clock = { "top_ahb", "ispif_ahb", "csi0_ahb", "ahb",
172 			   "csi0", "csi0_phy", "csi0_pix", "csi0_rdi" },
173 		.clock_rate = { { 0 },
174 				{ 0 },
175 				{ 0 },
176 				{ 0 },
177 				{ 100000000, 200000000, 266666667 },
178 				{ 0 },
179 				{ 0 },
180 				{ 0 } },
181 		.reg = { "csid0" },
182 		.interrupt = { "csid0" }
183 	},
184 
185 	/* CSID1 */
186 	{
187 		.regulators = { "vdda" },
188 		.clock = { "top_ahb", "ispif_ahb", "csi1_ahb", "ahb",
189 			   "csi1", "csi1_phy", "csi1_pix", "csi1_rdi" },
190 		.clock_rate = { { 0 },
191 				{ 0 },
192 				{ 0 },
193 				{ 0 },
194 				{ 100000000, 200000000, 266666667 },
195 				{ 0 },
196 				{ 0 },
197 				{ 0 } },
198 		.reg = { "csid1" },
199 		.interrupt = { "csid1" }
200 	},
201 
202 	/* CSID2 */
203 	{
204 		.regulators = { "vdda" },
205 		.clock = { "top_ahb", "ispif_ahb", "csi2_ahb", "ahb",
206 			   "csi2", "csi2_phy", "csi2_pix", "csi2_rdi" },
207 		.clock_rate = { { 0 },
208 				{ 0 },
209 				{ 0 },
210 				{ 0 },
211 				{ 100000000, 200000000, 266666667 },
212 				{ 0 },
213 				{ 0 },
214 				{ 0 } },
215 		.reg = { "csid2" },
216 		.interrupt = { "csid2" }
217 	},
218 
219 	/* CSID3 */
220 	{
221 		.regulators = { "vdda" },
222 		.clock = { "top_ahb", "ispif_ahb", "csi3_ahb", "ahb",
223 			   "csi3", "csi3_phy", "csi3_pix", "csi3_rdi" },
224 		.clock_rate = { { 0 },
225 				{ 0 },
226 				{ 0 },
227 				{ 0 },
228 				{ 100000000, 200000000, 266666667 },
229 				{ 0 },
230 				{ 0 },
231 				{ 0 } },
232 		.reg = { "csid3" },
233 		.interrupt = { "csid3" }
234 	}
235 };
236 
237 static const struct resources_ispif ispif_res_8x96 = {
238 	/* ISPIF */
239 	.clock = { "top_ahb", "ahb", "ispif_ahb",
240 		   "csi0", "csi0_pix", "csi0_rdi",
241 		   "csi1", "csi1_pix", "csi1_rdi",
242 		   "csi2", "csi2_pix", "csi2_rdi",
243 		   "csi3", "csi3_pix", "csi3_rdi" },
244 	.clock_for_reset = { "vfe0", "csi_vfe0", "vfe1", "csi_vfe1" },
245 	.reg = { "ispif", "csi_clk_mux" },
246 	.interrupt = "ispif"
247 };
248 
249 static const struct resources vfe_res_8x96[] = {
250 	/* VFE0 */
251 	{
252 		.regulators = {},
253 		.clock = { "top_ahb", "ahb", "vfe0", "csi_vfe0", "vfe_ahb",
254 			   "vfe0_ahb", "vfe_axi", "vfe0_stream"},
255 		.clock_rate = { { 0 },
256 				{ 0 },
257 				{ 75000000, 100000000, 300000000,
258 				  320000000, 480000000, 600000000 },
259 				{ 0 },
260 				{ 0 },
261 				{ 0 },
262 				{ 0 },
263 				{ 0 } },
264 		.reg = { "vfe0" },
265 		.interrupt = { "vfe0" }
266 	},
267 
268 	/* VFE1 */
269 	{
270 		.regulators = {},
271 		.clock = { "top_ahb", "ahb", "vfe1", "csi_vfe1", "vfe_ahb",
272 			   "vfe1_ahb", "vfe_axi", "vfe1_stream"},
273 		.clock_rate = { { 0 },
274 				{ 0 },
275 				{ 75000000, 100000000, 300000000,
276 				  320000000, 480000000, 600000000 },
277 				{ 0 },
278 				{ 0 },
279 				{ 0 },
280 				{ 0 },
281 				{ 0 } },
282 		.reg = { "vfe1" },
283 		.interrupt = { "vfe1" }
284 	}
285 };
286 
287 static const struct resources csiphy_res_660[] = {
288 	/* CSIPHY0 */
289 	{
290 		.regulators = {},
291 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy0_timer",
292 			   "csi0_phy", "csiphy_ahb2crif" },
293 		.clock_rate = { { 0 },
294 				{ 0 },
295 				{ 0 },
296 				{ 100000000, 200000000, 269333333 },
297 				{ 0 } },
298 		.reg = { "csiphy0", "csiphy0_clk_mux" },
299 		.interrupt = { "csiphy0" }
300 	},
301 
302 	/* CSIPHY1 */
303 	{
304 		.regulators = {},
305 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy1_timer",
306 			   "csi1_phy", "csiphy_ahb2crif" },
307 		.clock_rate = { { 0 },
308 				{ 0 },
309 				{ 0 },
310 				{ 100000000, 200000000, 269333333 },
311 				{ 0 } },
312 		.reg = { "csiphy1", "csiphy1_clk_mux" },
313 		.interrupt = { "csiphy1" }
314 	},
315 
316 	/* CSIPHY2 */
317 	{
318 		.regulators = {},
319 		.clock = { "top_ahb", "ispif_ahb", "ahb", "csiphy2_timer",
320 			   "csi2_phy", "csiphy_ahb2crif" },
321 		.clock_rate = { { 0 },
322 				{ 0 },
323 				{ 0 },
324 				{ 100000000, 200000000, 269333333 },
325 				{ 0 } },
326 		.reg = { "csiphy2", "csiphy2_clk_mux" },
327 		.interrupt = { "csiphy2" }
328 	}
329 };
330 
331 static const struct resources csid_res_660[] = {
332 	/* CSID0 */
333 	{
334 		.regulators = { "vdda", "vdd_sec" },
335 		.clock = { "top_ahb", "ispif_ahb", "csi0_ahb", "ahb",
336 			   "csi0", "csi0_phy", "csi0_pix", "csi0_rdi",
337 			   "cphy_csid0" },
338 		.clock_rate = { { 0 },
339 				{ 0 },
340 				{ 0 },
341 				{ 0 },
342 				{ 100000000, 200000000, 310000000,
343 				  404000000, 465000000 },
344 				{ 0 },
345 				{ 0 },
346 				{ 0 },
347 				{ 0 } },
348 		.reg = { "csid0" },
349 		.interrupt = { "csid0" }
350 	},
351 
352 	/* CSID1 */
353 	{
354 		.regulators = { "vdda", "vdd_sec" },
355 		.clock = { "top_ahb", "ispif_ahb", "csi1_ahb", "ahb",
356 			   "csi1", "csi1_phy", "csi1_pix", "csi1_rdi",
357 			   "cphy_csid1" },
358 		.clock_rate = { { 0 },
359 				{ 0 },
360 				{ 0 },
361 				{ 0 },
362 				{ 100000000, 200000000, 310000000,
363 				  404000000, 465000000 },
364 				{ 0 },
365 				{ 0 },
366 				{ 0 },
367 				{ 0 } },
368 		.reg = { "csid1" },
369 		.interrupt = { "csid1" }
370 	},
371 
372 	/* CSID2 */
373 	{
374 		.regulators = { "vdda", "vdd_sec" },
375 		.clock = { "top_ahb", "ispif_ahb", "csi2_ahb", "ahb",
376 			   "csi2", "csi2_phy", "csi2_pix", "csi2_rdi",
377 			   "cphy_csid2" },
378 		.clock_rate = { { 0 },
379 				{ 0 },
380 				{ 0 },
381 				{ 0 },
382 				{ 100000000, 200000000, 310000000,
383 				  404000000, 465000000 },
384 				{ 0 },
385 				{ 0 },
386 				{ 0 },
387 				{ 0 } },
388 		.reg = { "csid2" },
389 		.interrupt = { "csid2" }
390 	},
391 
392 	/* CSID3 */
393 	{
394 		.regulators = { "vdda", "vdd_sec" },
395 		.clock = { "top_ahb", "ispif_ahb", "csi3_ahb", "ahb",
396 			   "csi3", "csi3_phy", "csi3_pix", "csi3_rdi",
397 			   "cphy_csid3" },
398 		.clock_rate = { { 0 },
399 				{ 0 },
400 				{ 0 },
401 				{ 0 },
402 				{ 100000000, 200000000, 310000000,
403 				  404000000, 465000000 },
404 				{ 0 },
405 				{ 0 },
406 				{ 0 },
407 				{ 0 } },
408 		.reg = { "csid3" },
409 		.interrupt = { "csid3" }
410 	}
411 };
412 
413 static const struct resources_ispif ispif_res_660 = {
414 	/* ISPIF */
415 	.clock = { "top_ahb", "ahb", "ispif_ahb",
416 		   "csi0", "csi0_pix", "csi0_rdi",
417 		   "csi1", "csi1_pix", "csi1_rdi",
418 		   "csi2", "csi2_pix", "csi2_rdi",
419 		   "csi3", "csi3_pix", "csi3_rdi" },
420 	.clock_for_reset = { "vfe0", "csi_vfe0", "vfe1", "csi_vfe1" },
421 	.reg = { "ispif", "csi_clk_mux" },
422 	.interrupt = "ispif"
423 };
424 
425 static const struct resources vfe_res_660[] = {
426 	/* VFE0 */
427 	{
428 		.regulators = {},
429 		.clock = { "throttle_axi", "top_ahb", "ahb", "vfe0",
430 			   "csi_vfe0", "vfe_ahb", "vfe0_ahb", "vfe_axi",
431 			   "vfe0_stream"},
432 		.clock_rate = { { 0 },
433 				{ 0 },
434 				{ 0 },
435 				{ 120000000, 200000000, 256000000,
436 				  300000000, 404000000, 480000000,
437 				  540000000, 576000000 },
438 				{ 0 },
439 				{ 0 },
440 				{ 0 },
441 				{ 0 },
442 				{ 0 } },
443 		.reg = { "vfe0" },
444 		.interrupt = { "vfe0" }
445 	},
446 
447 	/* VFE1 */
448 	{
449 		.regulators = {},
450 		.clock = { "throttle_axi", "top_ahb", "ahb", "vfe1",
451 			   "csi_vfe1", "vfe_ahb", "vfe1_ahb", "vfe_axi",
452 			   "vfe1_stream"},
453 		.clock_rate = { { 0 },
454 				{ 0 },
455 				{ 0 },
456 				{ 120000000, 200000000, 256000000,
457 				  300000000, 404000000, 480000000,
458 				  540000000, 576000000 },
459 				{ 0 },
460 				{ 0 },
461 				{ 0 },
462 				{ 0 },
463 				{ 0 } },
464 		.reg = { "vfe1" },
465 		.interrupt = { "vfe1" }
466 	}
467 };
468 
469 static const struct resources csiphy_res_845[] = {
470 	/* CSIPHY0 */
471 	{
472 		.regulators = {},
473 		.clock = { "camnoc_axi", "soc_ahb", "slow_ahb_src",
474 				"cpas_ahb", "cphy_rx_src", "csiphy0",
475 				"csiphy0_timer_src", "csiphy0_timer" },
476 		.clock_rate = { { 0 },
477 				{ 0 },
478 				{ 0 },
479 				{ 0 },
480 				{ 0 },
481 				{ 0 },
482 				{ 0 },
483 				{ 19200000, 240000000, 269333333 } },
484 		.reg = { "csiphy0" },
485 		.interrupt = { "csiphy0" }
486 	},
487 
488 	/* CSIPHY1 */
489 	{
490 		.regulators = {},
491 		.clock = { "camnoc_axi", "soc_ahb", "slow_ahb_src",
492 				"cpas_ahb", "cphy_rx_src", "csiphy1",
493 				"csiphy1_timer_src", "csiphy1_timer" },
494 		.clock_rate = { { 0 },
495 				{ 0 },
496 				{ 0 },
497 				{ 0 },
498 				{ 0 },
499 				{ 0 },
500 				{ 0 },
501 				{ 19200000, 240000000, 269333333 } },
502 		.reg = { "csiphy1" },
503 		.interrupt = { "csiphy1" }
504 	},
505 
506 	/* CSIPHY2 */
507 	{
508 		.regulators = {},
509 		.clock = { "camnoc_axi", "soc_ahb", "slow_ahb_src",
510 				"cpas_ahb", "cphy_rx_src", "csiphy2",
511 				"csiphy2_timer_src", "csiphy2_timer" },
512 		.clock_rate = { { 0 },
513 				{ 0 },
514 				{ 0 },
515 				{ 0 },
516 				{ 0 },
517 				{ 0 },
518 				{ 0 },
519 				{ 19200000, 240000000, 269333333 } },
520 		.reg = { "csiphy2" },
521 		.interrupt = { "csiphy2" }
522 	},
523 
524 	/* CSIPHY3 */
525 	{
526 		.regulators = {},
527 		.clock = { "camnoc_axi", "soc_ahb", "slow_ahb_src",
528 				"cpas_ahb", "cphy_rx_src", "csiphy3",
529 				"csiphy3_timer_src", "csiphy3_timer" },
530 		.clock_rate = { { 0 },
531 				{ 0 },
532 				{ 0 },
533 				{ 0 },
534 				{ 0 },
535 				{ 0 },
536 				{ 0 },
537 				{ 19200000, 240000000, 269333333 } },
538 		.reg = { "csiphy3" },
539 		.interrupt = { "csiphy3" }
540 	}
541 };
542 
543 static const struct resources csid_res_845[] = {
544 	/* CSID0 */
545 	{
546 		.regulators = { "vdda-phy", "vdda-pll" },
547 		.clock = { "cpas_ahb", "cphy_rx_src", "slow_ahb_src",
548 				"soc_ahb", "vfe0", "vfe0_src",
549 				"vfe0_cphy_rx", "csi0",
550 				"csi0_src" },
551 		.clock_rate = { { 0 },
552 				{ 384000000 },
553 				{ 80000000 },
554 				{ 0 },
555 				{ 19200000, 100000000, 320000000, 404000000, 480000000, 600000000 },
556 				{ 320000000 },
557 				{ 0 },
558 				{ 19200000, 75000000, 384000000, 538666667 },
559 				{ 384000000 } },
560 		.reg = { "csid0" },
561 		.interrupt = { "csid0" }
562 	},
563 
564 	/* CSID1 */
565 	{
566 		.regulators = { "vdda-phy", "vdda-pll" },
567 		.clock = { "cpas_ahb", "cphy_rx_src", "slow_ahb_src",
568 				"soc_ahb", "vfe1", "vfe1_src",
569 				"vfe1_cphy_rx", "csi1",
570 				"csi1_src" },
571 		.clock_rate = { { 0 },
572 				{ 384000000 },
573 				{ 80000000 },
574 				{ 0 },
575 				{ 19200000, 100000000, 320000000, 404000000, 480000000, 600000000 },
576 				{ 320000000 },
577 				{ 0 },
578 				{ 19200000, 75000000, 384000000, 538666667 },
579 				{ 384000000 } },
580 		.reg = { "csid1" },
581 		.interrupt = { "csid1" }
582 	},
583 
584 	/* CSID2 */
585 	{
586 		.regulators = { "vdda-phy", "vdda-pll" },
587 		.clock = { "cpas_ahb", "cphy_rx_src", "slow_ahb_src",
588 				"soc_ahb", "vfe_lite", "vfe_lite_src",
589 				"vfe_lite_cphy_rx", "csi2",
590 				"csi2_src" },
591 		.clock_rate = { { 0 },
592 				{ 384000000 },
593 				{ 80000000 },
594 				{ 0 },
595 				{ 19200000, 100000000, 320000000, 404000000, 480000000, 600000000 },
596 				{ 320000000 },
597 				{ 0 },
598 				{ 19200000, 75000000, 384000000, 538666667 },
599 				{ 384000000 } },
600 		.reg = { "csid2" },
601 		.interrupt = { "csid2" }
602 	}
603 };
604 
605 static const struct resources vfe_res_845[] = {
606 	/* VFE0 */
607 	{
608 		.regulators = {},
609 		.clock = { "camnoc_axi", "cpas_ahb", "slow_ahb_src",
610 				"soc_ahb", "vfe0", "vfe0_axi",
611 				"vfe0_src", "csi0",
612 				"csi0_src"},
613 		.clock_rate = { { 0 },
614 				{ 0 },
615 				{ 80000000 },
616 				{ 0 },
617 				{ 19200000, 100000000, 320000000, 404000000, 480000000, 600000000 },
618 				{ 0 },
619 				{ 320000000 },
620 				{ 19200000, 75000000, 384000000, 538666667 },
621 				{ 384000000 } },
622 		.reg = { "vfe0" },
623 		.interrupt = { "vfe0" }
624 	},
625 
626 	/* VFE1 */
627 	{
628 		.regulators = {},
629 		.clock = { "camnoc_axi", "cpas_ahb", "slow_ahb_src",
630 				"soc_ahb", "vfe1", "vfe1_axi",
631 				"vfe1_src", "csi1",
632 				"csi1_src"},
633 		.clock_rate = { { 0 },
634 				{ 0 },
635 				{ 80000000 },
636 				{ 0 },
637 				{ 19200000, 100000000, 320000000, 404000000, 480000000, 600000000 },
638 				{ 0 },
639 				{ 320000000 },
640 				{ 19200000, 75000000, 384000000, 538666667 },
641 				{ 384000000 } },
642 		.reg = { "vfe1" },
643 		.interrupt = { "vfe1" }
644 	},
645 
646 	/* VFE-lite */
647 	{
648 		.regulators = {},
649 		.clock = { "camnoc_axi", "cpas_ahb", "slow_ahb_src",
650 				"soc_ahb", "vfe_lite",
651 				"vfe_lite_src", "csi2",
652 				"csi2_src"},
653 		.clock_rate = { { 0 },
654 				{ 0 },
655 				{ 80000000 },
656 				{ 0 },
657 				{ 19200000, 100000000, 320000000, 404000000, 480000000, 600000000 },
658 				{ 320000000 },
659 				{ 19200000, 75000000, 384000000, 538666667 },
660 				{ 384000000 } },
661 		.reg = { "vfe_lite" },
662 		.interrupt = { "vfe_lite" }
663 	}
664 };
665 
666 static const struct resources csiphy_res_8250[] = {
667 	/* CSIPHY0 */
668 	{
669 		.regulators = {},
670 		.clock = { "csiphy0", "csiphy0_timer" },
671 		.clock_rate = { { 400000000 },
672 				{ 300000000 } },
673 		.reg = { "csiphy0" },
674 		.interrupt = { "csiphy0" }
675 	},
676 	/* CSIPHY1 */
677 	{
678 		.regulators = {},
679 		.clock = { "csiphy1", "csiphy1_timer" },
680 		.clock_rate = { { 400000000 },
681 				{ 300000000 } },
682 		.reg = { "csiphy1" },
683 		.interrupt = { "csiphy1" }
684 	},
685 	/* CSIPHY2 */
686 	{
687 		.regulators = {},
688 		.clock = { "csiphy2", "csiphy2_timer" },
689 		.clock_rate = { { 400000000 },
690 				{ 300000000 } },
691 		.reg = { "csiphy2" },
692 		.interrupt = { "csiphy2" }
693 	},
694 	/* CSIPHY3 */
695 	{
696 		.regulators = {},
697 		.clock = { "csiphy3", "csiphy3_timer" },
698 		.clock_rate = { { 400000000 },
699 				{ 300000000 } },
700 		.reg = { "csiphy3" },
701 		.interrupt = { "csiphy3" }
702 	},
703 	/* CSIPHY4 */
704 	{
705 		.regulators = {},
706 		.clock = { "csiphy4", "csiphy4_timer" },
707 		.clock_rate = { { 400000000 },
708 				{ 300000000 } },
709 		.reg = { "csiphy4" },
710 		.interrupt = { "csiphy4" }
711 	},
712 	/* CSIPHY5 */
713 	{
714 		.regulators = {},
715 		.clock = { "csiphy5", "csiphy5_timer" },
716 		.clock_rate = { { 400000000 },
717 				{ 300000000 } },
718 		.reg = { "csiphy5" },
719 		.interrupt = { "csiphy5" }
720 	}
721 };
722 
723 static const struct resources csid_res_8250[] = {
724 	/* CSID0 */
725 	{
726 		.regulators = { "vdda-phy", "vdda-pll" },
727 		.clock = { "vfe0_csid", "vfe0_cphy_rx", "vfe0", "vfe0_areg", "vfe0_ahb" },
728 		.clock_rate = { { 400000000 },
729 				{ 400000000 },
730 				{ 350000000, 475000000, 576000000, 720000000 },
731 				{ 100000000, 200000000, 300000000, 400000000 },
732 				{ 0 } },
733 		.reg = { "csid0" },
734 		.interrupt = { "csid0" }
735 	},
736 	/* CSID1 */
737 	{
738 		.regulators = { "vdda-phy", "vdda-pll" },
739 		.clock = { "vfe1_csid", "vfe1_cphy_rx", "vfe1", "vfe1_areg", "vfe1_ahb" },
740 		.clock_rate = { { 400000000 },
741 				{ 400000000 },
742 				{ 350000000, 475000000, 576000000, 720000000 },
743 				{ 100000000, 200000000, 300000000, 400000000 },
744 				{ 0 } },
745 		.reg = { "csid1" },
746 		.interrupt = { "csid1" }
747 	},
748 	/* CSID2 */
749 	{
750 		.regulators = { "vdda-phy", "vdda-pll" },
751 		.clock = { "vfe_lite_csid", "vfe_lite_cphy_rx", "vfe_lite",  "vfe_lite_ahb" },
752 		.clock_rate = { { 400000000 },
753 				{ 400000000 },
754 				{ 400000000, 480000000 },
755 				{ 0 } },
756 		.reg = { "csid2" },
757 		.interrupt = { "csid2" }
758 	},
759 	/* CSID3 */
760 	{
761 		.regulators = { "vdda-phy", "vdda-pll" },
762 		.clock = { "vfe_lite_csid", "vfe_lite_cphy_rx", "vfe_lite",  "vfe_lite_ahb" },
763 		.clock_rate = { { 400000000 },
764 				{ 400000000 },
765 				{ 400000000, 480000000 },
766 				{ 0 } },
767 		.reg = { "csid3" },
768 		.interrupt = { "csid3" }
769 	}
770 };
771 
772 static const struct resources vfe_res_8250[] = {
773 	/* VFE0 */
774 	{
775 		.regulators = {},
776 		.clock = { "camnoc_axi_src", "slow_ahb_src", "cpas_ahb",
777 			   "camnoc_axi", "vfe0_ahb", "vfe0_areg", "vfe0",
778 			   "vfe0_axi", "cam_hf_axi" },
779 		.clock_rate = { { 19200000, 300000000, 400000000, 480000000 },
780 				{ 19200000, 80000000 },
781 				{ 19200000 },
782 				{ 0 },
783 				{ 0 },
784 				{ 100000000, 200000000, 300000000, 400000000 },
785 				{ 350000000, 475000000, 576000000, 720000000 },
786 				{ 0 },
787 				{ 0 } },
788 		.reg = { "vfe0" },
789 		.interrupt = { "vfe0" }
790 	},
791 	/* VFE1 */
792 	{
793 		.regulators = {},
794 		.clock = { "camnoc_axi_src", "slow_ahb_src", "cpas_ahb",
795 			   "camnoc_axi", "vfe1_ahb", "vfe1_areg", "vfe1",
796 			   "vfe1_axi", "cam_hf_axi" },
797 		.clock_rate = { { 19200000, 300000000, 400000000, 480000000 },
798 				{ 19200000, 80000000 },
799 				{ 19200000 },
800 				{ 0 },
801 				{ 0 },
802 				{ 100000000, 200000000, 300000000, 400000000 },
803 				{ 350000000, 475000000, 576000000, 720000000 },
804 				{ 0 },
805 				{ 0 } },
806 		.reg = { "vfe1" },
807 		.interrupt = { "vfe1" }
808 	},
809 	/* VFE2 (lite) */
810 	{
811 		.regulators = {},
812 		.clock = { "camnoc_axi_src", "slow_ahb_src", "cpas_ahb",
813 			   "camnoc_axi", "vfe_lite_ahb", "vfe_lite_axi",
814 			   "vfe_lite", "cam_hf_axi" },
815 		.clock_rate = { { 19200000, 300000000, 400000000, 480000000 },
816 				{ 19200000, 80000000 },
817 				{ 19200000 },
818 				{ 0 },
819 				{ 0 },
820 				{ 0 },
821 				{ 400000000, 480000000 },
822 				{ 0 } },
823 		.reg = { "vfe_lite0" },
824 		.interrupt = { "vfe_lite0" }
825 	},
826 	/* VFE3 (lite) */
827 	{
828 		.regulators = {},
829 		.clock = { "camnoc_axi_src", "slow_ahb_src", "cpas_ahb",
830 			   "camnoc_axi", "vfe_lite_ahb", "vfe_lite_axi",
831 			   "vfe_lite", "cam_hf_axi" },
832 		.clock_rate = { { 19200000, 300000000, 400000000, 480000000 },
833 				{ 19200000, 80000000 },
834 				{ 19200000 },
835 				{ 0 },
836 				{ 0 },
837 				{ 0 },
838 				{ 400000000, 480000000 },
839 				{ 0 } },
840 		.reg = { "vfe_lite1" },
841 		.interrupt = { "vfe_lite1" }
842 	},
843 };
844 
845 static const struct resources_icc icc_res_sm8250[] = {
846 	{
847 		.name = "cam_ahb",
848 		.icc_bw_tbl.avg = 38400,
849 		.icc_bw_tbl.peak = 76800,
850 	},
851 	{
852 		.name = "cam_hf_0_mnoc",
853 		.icc_bw_tbl.avg = 2097152,
854 		.icc_bw_tbl.peak = 2097152,
855 	},
856 	{
857 		.name = "cam_sf_0_mnoc",
858 		.icc_bw_tbl.avg = 0,
859 		.icc_bw_tbl.peak = 2097152,
860 	},
861 	{
862 		.name = "cam_sf_icp_mnoc",
863 		.icc_bw_tbl.avg = 2097152,
864 		.icc_bw_tbl.peak = 2097152,
865 	},
866 };
867 
868 /*
869  * camss_add_clock_margin - Add margin to clock frequency rate
870  * @rate: Clock frequency rate
871  *
872  * When making calculations with physical clock frequency values
873  * some safety margin must be added. Add it.
874  */
875 inline void camss_add_clock_margin(u64 *rate)
876 {
877 	*rate *= CAMSS_CLOCK_MARGIN_NUMERATOR;
878 	*rate = div_u64(*rate, CAMSS_CLOCK_MARGIN_DENOMINATOR);
879 }
880 
881 /*
882  * camss_enable_clocks - Enable multiple clocks
883  * @nclocks: Number of clocks in clock array
884  * @clock: Clock array
885  * @dev: Device
886  *
887  * Return 0 on success or a negative error code otherwise
888  */
889 int camss_enable_clocks(int nclocks, struct camss_clock *clock,
890 			struct device *dev)
891 {
892 	int ret;
893 	int i;
894 
895 	for (i = 0; i < nclocks; i++) {
896 		ret = clk_prepare_enable(clock[i].clk);
897 		if (ret) {
898 			dev_err(dev, "clock enable failed: %d\n", ret);
899 			goto error;
900 		}
901 	}
902 
903 	return 0;
904 
905 error:
906 	for (i--; i >= 0; i--)
907 		clk_disable_unprepare(clock[i].clk);
908 
909 	return ret;
910 }
911 
912 /*
913  * camss_disable_clocks - Disable multiple clocks
914  * @nclocks: Number of clocks in clock array
915  * @clock: Clock array
916  */
917 void camss_disable_clocks(int nclocks, struct camss_clock *clock)
918 {
919 	int i;
920 
921 	for (i = nclocks - 1; i >= 0; i--)
922 		clk_disable_unprepare(clock[i].clk);
923 }
924 
925 /*
926  * camss_find_sensor - Find a linked media entity which represents a sensor
927  * @entity: Media entity to start searching from
928  *
929  * Return a pointer to sensor media entity or NULL if not found
930  */
931 struct media_entity *camss_find_sensor(struct media_entity *entity)
932 {
933 	struct media_pad *pad;
934 
935 	while (1) {
936 		pad = &entity->pads[0];
937 		if (!(pad->flags & MEDIA_PAD_FL_SINK))
938 			return NULL;
939 
940 		pad = media_pad_remote_pad_first(pad);
941 		if (!pad || !is_media_entity_v4l2_subdev(pad->entity))
942 			return NULL;
943 
944 		entity = pad->entity;
945 
946 		if (entity->function == MEDIA_ENT_F_CAM_SENSOR)
947 			return entity;
948 	}
949 }
950 
951 /**
952  * camss_get_link_freq - Get link frequency from sensor
953  * @entity: Media entity in the current pipeline
954  * @bpp: Number of bits per pixel for the current format
955  * @lanes: Number of lanes in the link to the sensor
956  *
957  * Return link frequency on success or a negative error code otherwise
958  */
959 s64 camss_get_link_freq(struct media_entity *entity, unsigned int bpp,
960 			unsigned int lanes)
961 {
962 	struct media_entity *sensor;
963 	struct v4l2_subdev *subdev;
964 
965 	sensor = camss_find_sensor(entity);
966 	if (!sensor)
967 		return -ENODEV;
968 
969 	subdev = media_entity_to_v4l2_subdev(sensor);
970 
971 	return v4l2_get_link_freq(subdev->ctrl_handler, bpp, 2 * lanes);
972 }
973 
974 /*
975  * camss_get_pixel_clock - Get pixel clock rate from sensor
976  * @entity: Media entity in the current pipeline
977  * @pixel_clock: Received pixel clock value
978  *
979  * Return 0 on success or a negative error code otherwise
980  */
981 int camss_get_pixel_clock(struct media_entity *entity, u64 *pixel_clock)
982 {
983 	struct media_entity *sensor;
984 	struct v4l2_subdev *subdev;
985 	struct v4l2_ctrl *ctrl;
986 
987 	sensor = camss_find_sensor(entity);
988 	if (!sensor)
989 		return -ENODEV;
990 
991 	subdev = media_entity_to_v4l2_subdev(sensor);
992 
993 	ctrl = v4l2_ctrl_find(subdev->ctrl_handler, V4L2_CID_PIXEL_RATE);
994 
995 	if (!ctrl)
996 		return -EINVAL;
997 
998 	*pixel_clock = v4l2_ctrl_g_ctrl_int64(ctrl);
999 
1000 	return 0;
1001 }
1002 
1003 int camss_pm_domain_on(struct camss *camss, int id)
1004 {
1005 	int ret = 0;
1006 
1007 	if (id < camss->vfe_num) {
1008 		struct vfe_device *vfe = &camss->vfe[id];
1009 
1010 		ret = vfe->ops->pm_domain_on(vfe);
1011 	}
1012 
1013 	return ret;
1014 }
1015 
1016 void camss_pm_domain_off(struct camss *camss, int id)
1017 {
1018 	if (id < camss->vfe_num) {
1019 		struct vfe_device *vfe = &camss->vfe[id];
1020 
1021 		vfe->ops->pm_domain_off(vfe);
1022 	}
1023 }
1024 
1025 /*
1026  * camss_of_parse_endpoint_node - Parse port endpoint node
1027  * @dev: Device
1028  * @node: Device node to be parsed
1029  * @csd: Parsed data from port endpoint node
1030  *
1031  * Return 0 on success or a negative error code on failure
1032  */
1033 static int camss_of_parse_endpoint_node(struct device *dev,
1034 					struct device_node *node,
1035 					struct camss_async_subdev *csd)
1036 {
1037 	struct csiphy_lanes_cfg *lncfg = &csd->interface.csi2.lane_cfg;
1038 	struct v4l2_mbus_config_mipi_csi2 *mipi_csi2;
1039 	struct v4l2_fwnode_endpoint vep = { { 0 } };
1040 	unsigned int i;
1041 	int ret;
1042 
1043 	ret = v4l2_fwnode_endpoint_parse(of_fwnode_handle(node), &vep);
1044 	if (ret)
1045 		return ret;
1046 
1047 	csd->interface.csiphy_id = vep.base.port;
1048 
1049 	mipi_csi2 = &vep.bus.mipi_csi2;
1050 	lncfg->clk.pos = mipi_csi2->clock_lane;
1051 	lncfg->clk.pol = mipi_csi2->lane_polarities[0];
1052 	lncfg->num_data = mipi_csi2->num_data_lanes;
1053 
1054 	lncfg->data = devm_kcalloc(dev,
1055 				   lncfg->num_data, sizeof(*lncfg->data),
1056 				   GFP_KERNEL);
1057 	if (!lncfg->data)
1058 		return -ENOMEM;
1059 
1060 	for (i = 0; i < lncfg->num_data; i++) {
1061 		lncfg->data[i].pos = mipi_csi2->data_lanes[i];
1062 		lncfg->data[i].pol = mipi_csi2->lane_polarities[i + 1];
1063 	}
1064 
1065 	return 0;
1066 }
1067 
1068 /*
1069  * camss_of_parse_ports - Parse ports node
1070  * @dev: Device
1071  * @notifier: v4l2_device notifier data
1072  *
1073  * Return number of "port" nodes found in "ports" node
1074  */
1075 static int camss_of_parse_ports(struct camss *camss)
1076 {
1077 	struct device *dev = camss->dev;
1078 	struct device_node *node = NULL;
1079 	struct device_node *remote = NULL;
1080 	int ret, num_subdevs = 0;
1081 
1082 	for_each_endpoint_of_node(dev->of_node, node) {
1083 		struct camss_async_subdev *csd;
1084 
1085 		if (!of_device_is_available(node))
1086 			continue;
1087 
1088 		remote = of_graph_get_remote_port_parent(node);
1089 		if (!remote) {
1090 			dev_err(dev, "Cannot get remote parent\n");
1091 			ret = -EINVAL;
1092 			goto err_cleanup;
1093 		}
1094 
1095 		csd = v4l2_async_nf_add_fwnode(&camss->notifier,
1096 					       of_fwnode_handle(remote),
1097 					       struct camss_async_subdev);
1098 		of_node_put(remote);
1099 		if (IS_ERR(csd)) {
1100 			ret = PTR_ERR(csd);
1101 			goto err_cleanup;
1102 		}
1103 
1104 		ret = camss_of_parse_endpoint_node(dev, node, csd);
1105 		if (ret < 0)
1106 			goto err_cleanup;
1107 
1108 		num_subdevs++;
1109 	}
1110 
1111 	return num_subdevs;
1112 
1113 err_cleanup:
1114 	of_node_put(node);
1115 	return ret;
1116 }
1117 
1118 /*
1119  * camss_init_subdevices - Initialize subdev structures and resources
1120  * @camss: CAMSS device
1121  *
1122  * Return 0 on success or a negative error code on failure
1123  */
1124 static int camss_init_subdevices(struct camss *camss)
1125 {
1126 	const struct resources *csiphy_res;
1127 	const struct resources *csid_res;
1128 	const struct resources_ispif *ispif_res;
1129 	const struct resources *vfe_res;
1130 	unsigned int i;
1131 	int ret;
1132 
1133 	if (camss->version == CAMSS_8x16) {
1134 		csiphy_res = csiphy_res_8x16;
1135 		csid_res = csid_res_8x16;
1136 		ispif_res = &ispif_res_8x16;
1137 		vfe_res = vfe_res_8x16;
1138 	} else if (camss->version == CAMSS_8x96) {
1139 		csiphy_res = csiphy_res_8x96;
1140 		csid_res = csid_res_8x96;
1141 		ispif_res = &ispif_res_8x96;
1142 		vfe_res = vfe_res_8x96;
1143 	} else if (camss->version == CAMSS_660) {
1144 		csiphy_res = csiphy_res_660;
1145 		csid_res = csid_res_660;
1146 		ispif_res = &ispif_res_660;
1147 		vfe_res = vfe_res_660;
1148 	}  else if (camss->version == CAMSS_845) {
1149 		csiphy_res = csiphy_res_845;
1150 		csid_res = csid_res_845;
1151 		/* Titan VFEs don't have an ISPIF  */
1152 		ispif_res = NULL;
1153 		vfe_res = vfe_res_845;
1154 	} else if (camss->version == CAMSS_8250) {
1155 		csiphy_res = csiphy_res_8250;
1156 		csid_res = csid_res_8250;
1157 		/* Titan VFEs don't have an ISPIF  */
1158 		ispif_res = NULL;
1159 		vfe_res = vfe_res_8250;
1160 	} else {
1161 		return -EINVAL;
1162 	}
1163 
1164 	for (i = 0; i < camss->csiphy_num; i++) {
1165 		ret = msm_csiphy_subdev_init(camss, &camss->csiphy[i],
1166 					     &csiphy_res[i], i);
1167 		if (ret < 0) {
1168 			dev_err(camss->dev,
1169 				"Failed to init csiphy%d sub-device: %d\n",
1170 				i, ret);
1171 			return ret;
1172 		}
1173 	}
1174 
1175 	/* note: SM8250 requires VFE to be initialized before CSID */
1176 	for (i = 0; i < camss->vfe_num + camss->vfe_lite_num; i++) {
1177 		ret = msm_vfe_subdev_init(camss, &camss->vfe[i],
1178 					  &vfe_res[i], i);
1179 		if (ret < 0) {
1180 			dev_err(camss->dev,
1181 				"Fail to init vfe%d sub-device: %d\n", i, ret);
1182 			return ret;
1183 		}
1184 	}
1185 
1186 	for (i = 0; i < camss->csid_num; i++) {
1187 		ret = msm_csid_subdev_init(camss, &camss->csid[i],
1188 					   &csid_res[i], i);
1189 		if (ret < 0) {
1190 			dev_err(camss->dev,
1191 				"Failed to init csid%d sub-device: %d\n",
1192 				i, ret);
1193 			return ret;
1194 		}
1195 	}
1196 
1197 	ret = msm_ispif_subdev_init(camss, ispif_res);
1198 	if (ret < 0) {
1199 		dev_err(camss->dev, "Failed to init ispif sub-device: %d\n",
1200 		ret);
1201 		return ret;
1202 	}
1203 
1204 	return 0;
1205 }
1206 
1207 /*
1208  * camss_register_entities - Register subdev nodes and create links
1209  * @camss: CAMSS device
1210  *
1211  * Return 0 on success or a negative error code on failure
1212  */
1213 static int camss_register_entities(struct camss *camss)
1214 {
1215 	int i, j, k;
1216 	int ret;
1217 
1218 	for (i = 0; i < camss->csiphy_num; i++) {
1219 		ret = msm_csiphy_register_entity(&camss->csiphy[i],
1220 						 &camss->v4l2_dev);
1221 		if (ret < 0) {
1222 			dev_err(camss->dev,
1223 				"Failed to register csiphy%d entity: %d\n",
1224 				i, ret);
1225 			goto err_reg_csiphy;
1226 		}
1227 	}
1228 
1229 	for (i = 0; i < camss->csid_num; i++) {
1230 		ret = msm_csid_register_entity(&camss->csid[i],
1231 					       &camss->v4l2_dev);
1232 		if (ret < 0) {
1233 			dev_err(camss->dev,
1234 				"Failed to register csid%d entity: %d\n",
1235 				i, ret);
1236 			goto err_reg_csid;
1237 		}
1238 	}
1239 
1240 	ret = msm_ispif_register_entities(camss->ispif,
1241 					  &camss->v4l2_dev);
1242 	if (ret < 0) {
1243 		dev_err(camss->dev, "Failed to register ispif entities: %d\n",
1244 		ret);
1245 		goto err_reg_ispif;
1246 	}
1247 
1248 	for (i = 0; i < camss->vfe_num + camss->vfe_lite_num; i++) {
1249 		ret = msm_vfe_register_entities(&camss->vfe[i],
1250 						&camss->v4l2_dev);
1251 		if (ret < 0) {
1252 			dev_err(camss->dev,
1253 				"Failed to register vfe%d entities: %d\n",
1254 				i, ret);
1255 			goto err_reg_vfe;
1256 		}
1257 	}
1258 
1259 	for (i = 0; i < camss->csiphy_num; i++) {
1260 		for (j = 0; j < camss->csid_num; j++) {
1261 			ret = media_create_pad_link(
1262 				&camss->csiphy[i].subdev.entity,
1263 				MSM_CSIPHY_PAD_SRC,
1264 				&camss->csid[j].subdev.entity,
1265 				MSM_CSID_PAD_SINK,
1266 				0);
1267 			if (ret < 0) {
1268 				dev_err(camss->dev,
1269 					"Failed to link %s->%s entities: %d\n",
1270 					camss->csiphy[i].subdev.entity.name,
1271 					camss->csid[j].subdev.entity.name,
1272 					ret);
1273 				goto err_link;
1274 			}
1275 		}
1276 	}
1277 
1278 	if (camss->ispif) {
1279 		for (i = 0; i < camss->csid_num; i++) {
1280 			for (j = 0; j < camss->ispif->line_num; j++) {
1281 				ret = media_create_pad_link(
1282 					&camss->csid[i].subdev.entity,
1283 					MSM_CSID_PAD_SRC,
1284 					&camss->ispif->line[j].subdev.entity,
1285 					MSM_ISPIF_PAD_SINK,
1286 					0);
1287 				if (ret < 0) {
1288 					dev_err(camss->dev,
1289 						"Failed to link %s->%s entities: %d\n",
1290 						camss->csid[i].subdev.entity.name,
1291 						camss->ispif->line[j].subdev.entity.name,
1292 						ret);
1293 					goto err_link;
1294 				}
1295 			}
1296 		}
1297 
1298 		for (i = 0; i < camss->ispif->line_num; i++)
1299 			for (k = 0; k < camss->vfe_num; k++)
1300 				for (j = 0; j < camss->vfe[k].line_num; j++) {
1301 					struct v4l2_subdev *ispif = &camss->ispif->line[i].subdev;
1302 					struct v4l2_subdev *vfe = &camss->vfe[k].line[j].subdev;
1303 
1304 					ret = media_create_pad_link(&ispif->entity,
1305 								    MSM_ISPIF_PAD_SRC,
1306 								    &vfe->entity,
1307 								    MSM_VFE_PAD_SINK,
1308 								    0);
1309 					if (ret < 0) {
1310 						dev_err(camss->dev,
1311 							"Failed to link %s->%s entities: %d\n",
1312 							ispif->entity.name,
1313 							vfe->entity.name,
1314 							ret);
1315 						goto err_link;
1316 					}
1317 				}
1318 	} else {
1319 		for (i = 0; i < camss->csid_num; i++)
1320 			for (k = 0; k < camss->vfe_num + camss->vfe_lite_num; k++)
1321 				for (j = 0; j < camss->vfe[k].line_num; j++) {
1322 					struct v4l2_subdev *csid = &camss->csid[i].subdev;
1323 					struct v4l2_subdev *vfe = &camss->vfe[k].line[j].subdev;
1324 
1325 					ret = media_create_pad_link(&csid->entity,
1326 								    MSM_CSID_PAD_FIRST_SRC + j,
1327 								    &vfe->entity,
1328 								    MSM_VFE_PAD_SINK,
1329 								    0);
1330 					if (ret < 0) {
1331 						dev_err(camss->dev,
1332 							"Failed to link %s->%s entities: %d\n",
1333 							csid->entity.name,
1334 							vfe->entity.name,
1335 							ret);
1336 						goto err_link;
1337 					}
1338 				}
1339 	}
1340 
1341 	return 0;
1342 
1343 err_link:
1344 	i = camss->vfe_num + camss->vfe_lite_num;
1345 err_reg_vfe:
1346 	for (i--; i >= 0; i--)
1347 		msm_vfe_unregister_entities(&camss->vfe[i]);
1348 
1349 err_reg_ispif:
1350 	msm_ispif_unregister_entities(camss->ispif);
1351 
1352 	i = camss->csid_num;
1353 err_reg_csid:
1354 	for (i--; i >= 0; i--)
1355 		msm_csid_unregister_entity(&camss->csid[i]);
1356 
1357 	i = camss->csiphy_num;
1358 err_reg_csiphy:
1359 	for (i--; i >= 0; i--)
1360 		msm_csiphy_unregister_entity(&camss->csiphy[i]);
1361 
1362 	return ret;
1363 }
1364 
1365 /*
1366  * camss_unregister_entities - Unregister subdev nodes
1367  * @camss: CAMSS device
1368  *
1369  * Return 0 on success or a negative error code on failure
1370  */
1371 static void camss_unregister_entities(struct camss *camss)
1372 {
1373 	unsigned int i;
1374 
1375 	for (i = 0; i < camss->csiphy_num; i++)
1376 		msm_csiphy_unregister_entity(&camss->csiphy[i]);
1377 
1378 	for (i = 0; i < camss->csid_num; i++)
1379 		msm_csid_unregister_entity(&camss->csid[i]);
1380 
1381 	msm_ispif_unregister_entities(camss->ispif);
1382 
1383 	for (i = 0; i < camss->vfe_num + camss->vfe_lite_num; i++)
1384 		msm_vfe_unregister_entities(&camss->vfe[i]);
1385 }
1386 
1387 static int camss_subdev_notifier_bound(struct v4l2_async_notifier *async,
1388 				       struct v4l2_subdev *subdev,
1389 				       struct v4l2_async_connection *asd)
1390 {
1391 	struct camss *camss = container_of(async, struct camss, notifier);
1392 	struct camss_async_subdev *csd =
1393 		container_of(asd, struct camss_async_subdev, asd);
1394 	u8 id = csd->interface.csiphy_id;
1395 	struct csiphy_device *csiphy = &camss->csiphy[id];
1396 
1397 	csiphy->cfg.csi2 = &csd->interface.csi2;
1398 	subdev->host_priv = csiphy;
1399 
1400 	return 0;
1401 }
1402 
1403 static int camss_subdev_notifier_complete(struct v4l2_async_notifier *async)
1404 {
1405 	struct camss *camss = container_of(async, struct camss, notifier);
1406 	struct v4l2_device *v4l2_dev = &camss->v4l2_dev;
1407 	struct v4l2_subdev *sd;
1408 	int ret;
1409 
1410 	list_for_each_entry(sd, &v4l2_dev->subdevs, list) {
1411 		if (sd->host_priv) {
1412 			struct media_entity *sensor = &sd->entity;
1413 			struct csiphy_device *csiphy =
1414 					(struct csiphy_device *) sd->host_priv;
1415 			struct media_entity *input = &csiphy->subdev.entity;
1416 			unsigned int i;
1417 
1418 			for (i = 0; i < sensor->num_pads; i++) {
1419 				if (sensor->pads[i].flags & MEDIA_PAD_FL_SOURCE)
1420 					break;
1421 			}
1422 			if (i == sensor->num_pads) {
1423 				dev_err(camss->dev,
1424 					"No source pad in external entity\n");
1425 				return -EINVAL;
1426 			}
1427 
1428 			ret = media_create_pad_link(sensor, i,
1429 				input, MSM_CSIPHY_PAD_SINK,
1430 				MEDIA_LNK_FL_IMMUTABLE | MEDIA_LNK_FL_ENABLED);
1431 			if (ret < 0) {
1432 				dev_err(camss->dev,
1433 					"Failed to link %s->%s entities: %d\n",
1434 					sensor->name, input->name, ret);
1435 				return ret;
1436 			}
1437 		}
1438 	}
1439 
1440 	ret = v4l2_device_register_subdev_nodes(&camss->v4l2_dev);
1441 	if (ret < 0)
1442 		return ret;
1443 
1444 	return media_device_register(&camss->media_dev);
1445 }
1446 
1447 static const struct v4l2_async_notifier_operations camss_subdev_notifier_ops = {
1448 	.bound = camss_subdev_notifier_bound,
1449 	.complete = camss_subdev_notifier_complete,
1450 };
1451 
1452 static const struct media_device_ops camss_media_ops = {
1453 	.link_notify = v4l2_pipeline_link_notify,
1454 };
1455 
1456 static int camss_configure_pd(struct camss *camss)
1457 {
1458 	struct device *dev = camss->dev;
1459 	int i;
1460 	int ret;
1461 
1462 	camss->genpd_num = of_count_phandle_with_args(dev->of_node,
1463 						      "power-domains",
1464 						      "#power-domain-cells");
1465 	if (camss->genpd_num < 0) {
1466 		dev_err(dev, "Power domains are not defined for camss\n");
1467 		return camss->genpd_num;
1468 	}
1469 
1470 	/*
1471 	 * If a platform device has just one power domain, then it is attached
1472 	 * at platform_probe() level, thus there shall be no need and even no
1473 	 * option to attach it again, this is the case for CAMSS on MSM8916.
1474 	 */
1475 	if (camss->genpd_num == 1)
1476 		return 0;
1477 
1478 	camss->genpd = devm_kmalloc_array(dev, camss->genpd_num,
1479 					  sizeof(*camss->genpd), GFP_KERNEL);
1480 	if (!camss->genpd)
1481 		return -ENOMEM;
1482 
1483 	camss->genpd_link = devm_kmalloc_array(dev, camss->genpd_num,
1484 					       sizeof(*camss->genpd_link),
1485 					       GFP_KERNEL);
1486 	if (!camss->genpd_link)
1487 		return -ENOMEM;
1488 
1489 	/*
1490 	 * VFE power domains are in the beginning of the list, and while all
1491 	 * power domains should be attached, only if TITAN_TOP power domain is
1492 	 * found in the list, it should be linked over here.
1493 	 */
1494 	for (i = 0; i < camss->genpd_num; i++) {
1495 		camss->genpd[i] = dev_pm_domain_attach_by_id(camss->dev, i);
1496 		if (IS_ERR(camss->genpd[i])) {
1497 			ret = PTR_ERR(camss->genpd[i]);
1498 			goto fail_pm;
1499 		}
1500 	}
1501 
1502 	if (i > camss->vfe_num) {
1503 		camss->genpd_link[i - 1] = device_link_add(camss->dev, camss->genpd[i - 1],
1504 							   DL_FLAG_STATELESS | DL_FLAG_PM_RUNTIME |
1505 							   DL_FLAG_RPM_ACTIVE);
1506 		if (!camss->genpd_link[i - 1]) {
1507 			ret = -EINVAL;
1508 			goto fail_pm;
1509 		}
1510 	}
1511 
1512 	return 0;
1513 
1514 fail_pm:
1515 	for (--i ; i >= 0; i--)
1516 		dev_pm_domain_detach(camss->genpd[i], true);
1517 
1518 	return ret;
1519 }
1520 
1521 static int camss_icc_get(struct camss *camss)
1522 {
1523 	const struct resources_icc *icc_res;
1524 	int nbr_icc_paths = 0;
1525 	int i;
1526 
1527 	if (camss->version == CAMSS_8250) {
1528 		icc_res = &icc_res_sm8250[0];
1529 		nbr_icc_paths =	ICC_SM8250_COUNT;
1530 	}
1531 
1532 	for (i = 0; i < nbr_icc_paths; i++) {
1533 		camss->icc_path[i] = devm_of_icc_get(camss->dev,
1534 						     icc_res[i].name);
1535 		if (IS_ERR(camss->icc_path[i]))
1536 			return PTR_ERR(camss->icc_path[i]);
1537 
1538 		camss->icc_bw_tbl[i] = icc_res[i].icc_bw_tbl;
1539 	}
1540 
1541 	return 0;
1542 }
1543 
1544 static void camss_genpd_cleanup(struct camss *camss)
1545 {
1546 	int i;
1547 
1548 	if (camss->genpd_num == 1)
1549 		return;
1550 
1551 	if (camss->genpd_num > camss->vfe_num)
1552 		device_link_del(camss->genpd_link[camss->genpd_num - 1]);
1553 
1554 	for (i = 0; i < camss->genpd_num; i++)
1555 		dev_pm_domain_detach(camss->genpd[i], true);
1556 }
1557 
1558 /*
1559  * camss_probe - Probe CAMSS platform device
1560  * @pdev: Pointer to CAMSS platform device
1561  *
1562  * Return 0 on success or a negative error code on failure
1563  */
1564 static int camss_probe(struct platform_device *pdev)
1565 {
1566 	struct device *dev = &pdev->dev;
1567 	struct camss *camss;
1568 	int num_subdevs, ret;
1569 
1570 	camss = devm_kzalloc(dev, sizeof(*camss), GFP_KERNEL);
1571 	if (!camss)
1572 		return -ENOMEM;
1573 
1574 	atomic_set(&camss->ref_count, 0);
1575 	camss->dev = dev;
1576 	platform_set_drvdata(pdev, camss);
1577 
1578 	if (of_device_is_compatible(dev->of_node, "qcom,msm8916-camss")) {
1579 		camss->version = CAMSS_8x16;
1580 		camss->csiphy_num = 2;
1581 		camss->csid_num = 2;
1582 		camss->vfe_num = 1;
1583 	} else if (of_device_is_compatible(dev->of_node,
1584 					   "qcom,msm8996-camss")) {
1585 		camss->version = CAMSS_8x96;
1586 		camss->csiphy_num = 3;
1587 		camss->csid_num = 4;
1588 		camss->vfe_num = 2;
1589 	} else if (of_device_is_compatible(dev->of_node,
1590 					   "qcom,sdm660-camss")) {
1591 		camss->version = CAMSS_660;
1592 		camss->csiphy_num = 3;
1593 		camss->csid_num = 4;
1594 		camss->vfe_num = 2;
1595 	} else if (of_device_is_compatible(dev->of_node,
1596 					   "qcom,sdm845-camss")) {
1597 		camss->version = CAMSS_845;
1598 		camss->csiphy_num = 4;
1599 		camss->csid_num = 3;
1600 		camss->vfe_num = 2;
1601 		camss->vfe_lite_num = 1;
1602 	} else if (of_device_is_compatible(dev->of_node,
1603 					   "qcom,sm8250-camss")) {
1604 		camss->version = CAMSS_8250;
1605 		camss->csiphy_num = 6;
1606 		camss->csid_num = 4;
1607 		camss->vfe_num = 2;
1608 		camss->vfe_lite_num = 2;
1609 	} else {
1610 		return -EINVAL;
1611 	}
1612 
1613 	camss->csiphy = devm_kcalloc(dev, camss->csiphy_num,
1614 				     sizeof(*camss->csiphy), GFP_KERNEL);
1615 	if (!camss->csiphy)
1616 		return -ENOMEM;
1617 
1618 	camss->csid = devm_kcalloc(dev, camss->csid_num, sizeof(*camss->csid),
1619 				   GFP_KERNEL);
1620 	if (!camss->csid)
1621 		return -ENOMEM;
1622 
1623 	if (camss->version == CAMSS_8x16 ||
1624 	    camss->version == CAMSS_8x96) {
1625 		camss->ispif = devm_kcalloc(dev, 1, sizeof(*camss->ispif), GFP_KERNEL);
1626 		if (!camss->ispif)
1627 			return -ENOMEM;
1628 	}
1629 
1630 	camss->vfe = devm_kcalloc(dev, camss->vfe_num + camss->vfe_lite_num,
1631 				  sizeof(*camss->vfe), GFP_KERNEL);
1632 	if (!camss->vfe)
1633 		return -ENOMEM;
1634 
1635 	ret = camss_icc_get(camss);
1636 	if (ret < 0)
1637 		return ret;
1638 
1639 	ret = camss_configure_pd(camss);
1640 	if (ret < 0) {
1641 		dev_err(dev, "Failed to configure power domains: %d\n", ret);
1642 		return ret;
1643 	}
1644 
1645 	ret = camss_init_subdevices(camss);
1646 	if (ret < 0)
1647 		goto err_genpd_cleanup;
1648 
1649 	ret = dma_set_mask_and_coherent(dev, 0xffffffff);
1650 	if (ret)
1651 		goto err_genpd_cleanup;
1652 
1653 	camss->media_dev.dev = camss->dev;
1654 	strscpy(camss->media_dev.model, "Qualcomm Camera Subsystem",
1655 		sizeof(camss->media_dev.model));
1656 	camss->media_dev.ops = &camss_media_ops;
1657 	media_device_init(&camss->media_dev);
1658 
1659 	camss->v4l2_dev.mdev = &camss->media_dev;
1660 	ret = v4l2_device_register(camss->dev, &camss->v4l2_dev);
1661 	if (ret < 0) {
1662 		dev_err(dev, "Failed to register V4L2 device: %d\n", ret);
1663 		goto err_genpd_cleanup;
1664 	}
1665 
1666 	v4l2_async_nf_init(&camss->notifier, &camss->v4l2_dev);
1667 
1668 	num_subdevs = camss_of_parse_ports(camss);
1669 	if (num_subdevs < 0) {
1670 		ret = num_subdevs;
1671 		goto err_v4l2_device_unregister;
1672 	}
1673 
1674 	ret = camss_register_entities(camss);
1675 	if (ret < 0)
1676 		goto err_v4l2_device_unregister;
1677 
1678 	if (num_subdevs) {
1679 		camss->notifier.ops = &camss_subdev_notifier_ops;
1680 
1681 		ret = v4l2_async_nf_register(&camss->notifier);
1682 		if (ret) {
1683 			dev_err(dev,
1684 				"Failed to register async subdev nodes: %d\n",
1685 				ret);
1686 			goto err_register_subdevs;
1687 		}
1688 	} else {
1689 		ret = v4l2_device_register_subdev_nodes(&camss->v4l2_dev);
1690 		if (ret < 0) {
1691 			dev_err(dev, "Failed to register subdev nodes: %d\n",
1692 				ret);
1693 			goto err_register_subdevs;
1694 		}
1695 
1696 		ret = media_device_register(&camss->media_dev);
1697 		if (ret < 0) {
1698 			dev_err(dev, "Failed to register media device: %d\n",
1699 				ret);
1700 			goto err_register_subdevs;
1701 		}
1702 	}
1703 
1704 	pm_runtime_enable(dev);
1705 
1706 	return 0;
1707 
1708 err_register_subdevs:
1709 	camss_unregister_entities(camss);
1710 err_v4l2_device_unregister:
1711 	v4l2_device_unregister(&camss->v4l2_dev);
1712 	v4l2_async_nf_cleanup(&camss->notifier);
1713 err_genpd_cleanup:
1714 	camss_genpd_cleanup(camss);
1715 
1716 	return ret;
1717 }
1718 
1719 void camss_delete(struct camss *camss)
1720 {
1721 	v4l2_device_unregister(&camss->v4l2_dev);
1722 	media_device_unregister(&camss->media_dev);
1723 	media_device_cleanup(&camss->media_dev);
1724 
1725 	pm_runtime_disable(camss->dev);
1726 }
1727 
1728 /*
1729  * camss_remove - Remove CAMSS platform device
1730  * @pdev: Pointer to CAMSS platform device
1731  *
1732  * Always returns 0.
1733  */
1734 static void camss_remove(struct platform_device *pdev)
1735 {
1736 	struct camss *camss = platform_get_drvdata(pdev);
1737 
1738 	v4l2_async_nf_unregister(&camss->notifier);
1739 	v4l2_async_nf_cleanup(&camss->notifier);
1740 	camss_unregister_entities(camss);
1741 
1742 	if (atomic_read(&camss->ref_count) == 0)
1743 		camss_delete(camss);
1744 
1745 	camss_genpd_cleanup(camss);
1746 }
1747 
1748 static const struct of_device_id camss_dt_match[] = {
1749 	{ .compatible = "qcom,msm8916-camss" },
1750 	{ .compatible = "qcom,msm8996-camss" },
1751 	{ .compatible = "qcom,sdm660-camss" },
1752 	{ .compatible = "qcom,sdm845-camss" },
1753 	{ .compatible = "qcom,sm8250-camss" },
1754 	{ }
1755 };
1756 
1757 MODULE_DEVICE_TABLE(of, camss_dt_match);
1758 
1759 static int __maybe_unused camss_runtime_suspend(struct device *dev)
1760 {
1761 	struct camss *camss = dev_get_drvdata(dev);
1762 	int nbr_icc_paths = 0;
1763 	int i;
1764 	int ret;
1765 
1766 	if (camss->version == CAMSS_8250)
1767 		nbr_icc_paths =	ICC_SM8250_COUNT;
1768 
1769 	for (i = 0; i < nbr_icc_paths; i++) {
1770 		ret = icc_set_bw(camss->icc_path[i], 0, 0);
1771 		if (ret)
1772 			return ret;
1773 	}
1774 
1775 	return 0;
1776 }
1777 
1778 static int __maybe_unused camss_runtime_resume(struct device *dev)
1779 {
1780 	struct camss *camss = dev_get_drvdata(dev);
1781 	int nbr_icc_paths = 0;
1782 	int i;
1783 	int ret;
1784 
1785 	if (camss->version == CAMSS_8250)
1786 		nbr_icc_paths =	ICC_SM8250_COUNT;
1787 
1788 	for (i = 0; i < nbr_icc_paths; i++) {
1789 		ret = icc_set_bw(camss->icc_path[i],
1790 				 camss->icc_bw_tbl[i].avg,
1791 				 camss->icc_bw_tbl[i].peak);
1792 		if (ret)
1793 			return ret;
1794 	}
1795 
1796 	return 0;
1797 }
1798 
1799 static const struct dev_pm_ops camss_pm_ops = {
1800 	SET_SYSTEM_SLEEP_PM_OPS(pm_runtime_force_suspend,
1801 				pm_runtime_force_resume)
1802 	SET_RUNTIME_PM_OPS(camss_runtime_suspend, camss_runtime_resume, NULL)
1803 };
1804 
1805 static struct platform_driver qcom_camss_driver = {
1806 	.probe = camss_probe,
1807 	.remove_new = camss_remove,
1808 	.driver = {
1809 		.name = "qcom-camss",
1810 		.of_match_table = camss_dt_match,
1811 		.pm = &camss_pm_ops,
1812 	},
1813 };
1814 
1815 module_platform_driver(qcom_camss_driver);
1816 
1817 MODULE_ALIAS("platform:qcom-camss");
1818 MODULE_DESCRIPTION("Qualcomm Camera Subsystem driver");
1819 MODULE_AUTHOR("Todor Tomov <todor.tomov@linaro.org>");
1820 MODULE_LICENSE("GPL v2");
1821