mxc_hdmi.h
43.4 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
/*
* Copyright (C) 2011-2015 Freescale Semiconductor, Inc.
*/
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef __MXC_HDMI_H__
#define __MXC_HDMI_H__
/*
* Hdmi controller registers
*/
/* Identification Registers */
#define HDMI_DESIGN_ID 0x0000
#define HDMI_REVISION_ID 0x0001
#define HDMI_PRODUCT_ID0 0x0002
#define HDMI_PRODUCT_ID1 0x0003
#define HDMI_CONFIG0_ID 0x0004
#define HDMI_CONFIG1_ID 0x0005
#define HDMI_CONFIG2_ID 0x0006
#define HDMI_CONFIG3_ID 0x0007
/* Interrupt Registers */
#define HDMI_IH_FC_STAT0 0x0100
#define HDMI_IH_FC_STAT1 0x0101
#define HDMI_IH_FC_STAT2 0x0102
#define HDMI_IH_AS_STAT0 0x0103
#define HDMI_IH_PHY_STAT0 0x0104
#define HDMI_IH_I2CM_STAT0 0x0105
#define HDMI_IH_CEC_STAT0 0x0106
#define HDMI_IH_VP_STAT0 0x0107
#define HDMI_IH_I2CMPHY_STAT0 0x0108
#define HDMI_IH_AHBDMAAUD_STAT0 0x0109
#define HDMI_IH_MUTE_FC_STAT0 0x0180
#define HDMI_IH_MUTE_FC_STAT1 0x0181
#define HDMI_IH_MUTE_FC_STAT2 0x0182
#define HDMI_IH_MUTE_AS_STAT0 0x0183
#define HDMI_IH_MUTE_PHY_STAT0 0x0184
#define HDMI_IH_MUTE_I2CM_STAT0 0x0185
#define HDMI_IH_MUTE_CEC_STAT0 0x0186
#define HDMI_IH_MUTE_VP_STAT0 0x0187
#define HDMI_IH_MUTE_I2CMPHY_STAT0 0x0188
#define HDMI_IH_MUTE_AHBDMAAUD_STAT0 0x0189
#define HDMI_IH_MUTE 0x01FF
/* Video Sample Registers */
#define HDMI_TX_INVID0 0x0200
#define HDMI_TX_INSTUFFING 0x0201
#define HDMI_TX_GYDATA0 0x0202
#define HDMI_TX_GYDATA1 0x0203
#define HDMI_TX_RCRDATA0 0x0204
#define HDMI_TX_RCRDATA1 0x0205
#define HDMI_TX_BCBDATA0 0x0206
#define HDMI_TX_BCBDATA1 0x0207
/* Video Packetizer Registers */
#define HDMI_VP_STATUS 0x0800
#define HDMI_VP_PR_CD 0x0801
#define HDMI_VP_STUFF 0x0802
#define HDMI_VP_REMAP 0x0803
#define HDMI_VP_CONF 0x0804
#define HDMI_VP_STAT 0x0805
#define HDMI_VP_INT 0x0806
#define HDMI_VP_MASK 0x0807
#define HDMI_VP_POL 0x0808
/* Frame Composer Registers */
#define HDMI_FC_INVIDCONF 0x1000
#define HDMI_FC_INHACTV0 0x1001
#define HDMI_FC_INHACTV1 0x1002
#define HDMI_FC_INHBLANK0 0x1003
#define HDMI_FC_INHBLANK1 0x1004
#define HDMI_FC_INVACTV0 0x1005
#define HDMI_FC_INVACTV1 0x1006
#define HDMI_FC_INVBLANK 0x1007
#define HDMI_FC_HSYNCINDELAY0 0x1008
#define HDMI_FC_HSYNCINDELAY1 0x1009
#define HDMI_FC_HSYNCINWIDTH0 0x100A
#define HDMI_FC_HSYNCINWIDTH1 0x100B
#define HDMI_FC_VSYNCINDELAY 0x100C
#define HDMI_FC_VSYNCINWIDTH 0x100D
#define HDMI_FC_INFREQ0 0x100E
#define HDMI_FC_INFREQ1 0x100F
#define HDMI_FC_INFREQ2 0x1010
#define HDMI_FC_CTRLDUR 0x1011
#define HDMI_FC_EXCTRLDUR 0x1012
#define HDMI_FC_EXCTRLSPAC 0x1013
#define HDMI_FC_CH0PREAM 0x1014
#define HDMI_FC_CH1PREAM 0x1015
#define HDMI_FC_CH2PREAM 0x1016
#define HDMI_FC_AVICONF3 0x1017
#define HDMI_FC_GCP 0x1018
#define HDMI_FC_AVICONF0 0x1019
#define HDMI_FC_AVICONF1 0x101A
#define HDMI_FC_AVICONF2 0x101B
#define HDMI_FC_AVIVID 0x101C
#define HDMI_FC_AVIETB0 0x101D
#define HDMI_FC_AVIETB1 0x101E
#define HDMI_FC_AVISBB0 0x101F
#define HDMI_FC_AVISBB1 0x1020
#define HDMI_FC_AVIELB0 0x1021
#define HDMI_FC_AVIELB1 0x1022
#define HDMI_FC_AVISRB0 0x1023
#define HDMI_FC_AVISRB1 0x1024
#define HDMI_FC_AUDICONF0 0x1025
#define HDMI_FC_AUDICONF1 0x1026
#define HDMI_FC_AUDICONF2 0x1027
#define HDMI_FC_AUDICONF3 0x1028
#define HDMI_FC_VSDIEEEID0 0x1029
#define HDMI_FC_VSDSIZE 0x102A
#define HDMI_FC_VSDIEEEID1 0x1030
#define HDMI_FC_VSDIEEEID2 0x1031
#define HDMI_FC_VSDPAYLOAD0 0x1032
#define HDMI_FC_VSDPAYLOAD1 0x1033
#define HDMI_FC_VSDPAYLOAD2 0x1034
#define HDMI_FC_VSDPAYLOAD3 0x1035
#define HDMI_FC_VSDPAYLOAD4 0x1036
#define HDMI_FC_VSDPAYLOAD5 0x1037
#define HDMI_FC_VSDPAYLOAD6 0x1038
#define HDMI_FC_VSDPAYLOAD7 0x1039
#define HDMI_FC_VSDPAYLOAD8 0x103A
#define HDMI_FC_VSDPAYLOAD9 0x103B
#define HDMI_FC_VSDPAYLOAD10 0x103C
#define HDMI_FC_VSDPAYLOAD11 0x103D
#define HDMI_FC_VSDPAYLOAD12 0x103E
#define HDMI_FC_VSDPAYLOAD13 0x103F
#define HDMI_FC_VSDPAYLOAD14 0x1040
#define HDMI_FC_VSDPAYLOAD15 0x1041
#define HDMI_FC_VSDPAYLOAD16 0x1042
#define HDMI_FC_VSDPAYLOAD17 0x1043
#define HDMI_FC_VSDPAYLOAD18 0x1044
#define HDMI_FC_VSDPAYLOAD19 0x1045
#define HDMI_FC_VSDPAYLOAD20 0x1046
#define HDMI_FC_VSDPAYLOAD21 0x1047
#define HDMI_FC_VSDPAYLOAD22 0x1048
#define HDMI_FC_VSDPAYLOAD23 0x1049
#define HDMI_FC_SPDVENDORNAME0 0x104A
#define HDMI_FC_SPDVENDORNAME1 0x104B
#define HDMI_FC_SPDVENDORNAME2 0x104C
#define HDMI_FC_SPDVENDORNAME3 0x104D
#define HDMI_FC_SPDVENDORNAME4 0x104E
#define HDMI_FC_SPDVENDORNAME5 0x104F
#define HDMI_FC_SPDVENDORNAME6 0x1050
#define HDMI_FC_SPDVENDORNAME7 0x1051
#define HDMI_FC_SDPPRODUCTNAME0 0x1052
#define HDMI_FC_SDPPRODUCTNAME1 0x1053
#define HDMI_FC_SDPPRODUCTNAME2 0x1054
#define HDMI_FC_SDPPRODUCTNAME3 0x1055
#define HDMI_FC_SDPPRODUCTNAME4 0x1056
#define HDMI_FC_SDPPRODUCTNAME5 0x1057
#define HDMI_FC_SDPPRODUCTNAME6 0x1058
#define HDMI_FC_SDPPRODUCTNAME7 0x1059
#define HDMI_FC_SDPPRODUCTNAME8 0x105A
#define HDMI_FC_SDPPRODUCTNAME9 0x105B
#define HDMI_FC_SDPPRODUCTNAME10 0x105C
#define HDMI_FC_SDPPRODUCTNAME11 0x105D
#define HDMI_FC_SDPPRODUCTNAME12 0x105E
#define HDMI_FC_SDPPRODUCTNAME13 0x105F
#define HDMI_FC_SDPPRODUCTNAME14 0x1060
#define HDMI_FC_SPDPRODUCTNAME15 0x1061
#define HDMI_FC_SPDDEVICEINF 0x1062
#define HDMI_FC_AUDSCONF 0x1063
#define HDMI_FC_AUDSSTAT 0x1064
#define HDMI_FC_DATACH0FILL 0x1070
#define HDMI_FC_DATACH1FILL 0x1071
#define HDMI_FC_DATACH2FILL 0x1072
#define HDMI_FC_CTRLQHIGH 0x1073
#define HDMI_FC_CTRLQLOW 0x1074
#define HDMI_FC_ACP0 0x1075
#define HDMI_FC_ACP28 0x1076
#define HDMI_FC_ACP27 0x1077
#define HDMI_FC_ACP26 0x1078
#define HDMI_FC_ACP25 0x1079
#define HDMI_FC_ACP24 0x107A
#define HDMI_FC_ACP23 0x107B
#define HDMI_FC_ACP22 0x107C
#define HDMI_FC_ACP21 0x107D
#define HDMI_FC_ACP20 0x107E
#define HDMI_FC_ACP19 0x107F
#define HDMI_FC_ACP18 0x1080
#define HDMI_FC_ACP17 0x1081
#define HDMI_FC_ACP16 0x1082
#define HDMI_FC_ACP15 0x1083
#define HDMI_FC_ACP14 0x1084
#define HDMI_FC_ACP13 0x1085
#define HDMI_FC_ACP12 0x1086
#define HDMI_FC_ACP11 0x1087
#define HDMI_FC_ACP10 0x1088
#define HDMI_FC_ACP9 0x1089
#define HDMI_FC_ACP8 0x108A
#define HDMI_FC_ACP7 0x108B
#define HDMI_FC_ACP6 0x108C
#define HDMI_FC_ACP5 0x108D
#define HDMI_FC_ACP4 0x108E
#define HDMI_FC_ACP3 0x108F
#define HDMI_FC_ACP2 0x1090
#define HDMI_FC_ACP1 0x1091
#define HDMI_FC_ISCR1_0 0x1092
#define HDMI_FC_ISCR1_16 0x1093
#define HDMI_FC_ISCR1_15 0x1094
#define HDMI_FC_ISCR1_14 0x1095
#define HDMI_FC_ISCR1_13 0x1096
#define HDMI_FC_ISCR1_12 0x1097
#define HDMI_FC_ISCR1_11 0x1098
#define HDMI_FC_ISCR1_10 0x1099
#define HDMI_FC_ISCR1_9 0x109A
#define HDMI_FC_ISCR1_8 0x109B
#define HDMI_FC_ISCR1_7 0x109C
#define HDMI_FC_ISCR1_6 0x109D
#define HDMI_FC_ISCR1_5 0x109E
#define HDMI_FC_ISCR1_4 0x109F
#define HDMI_FC_ISCR1_3 0x10A0
#define HDMI_FC_ISCR1_2 0x10A1
#define HDMI_FC_ISCR1_1 0x10A2
#define HDMI_FC_ISCR2_15 0x10A3
#define HDMI_FC_ISCR2_14 0x10A4
#define HDMI_FC_ISCR2_13 0x10A5
#define HDMI_FC_ISCR2_12 0x10A6
#define HDMI_FC_ISCR2_11 0x10A7
#define HDMI_FC_ISCR2_10 0x10A8
#define HDMI_FC_ISCR2_9 0x10A9
#define HDMI_FC_ISCR2_8 0x10AA
#define HDMI_FC_ISCR2_7 0x10AB
#define HDMI_FC_ISCR2_6 0x10AC
#define HDMI_FC_ISCR2_5 0x10AD
#define HDMI_FC_ISCR2_4 0x10AE
#define HDMI_FC_ISCR2_3 0x10AF
#define HDMI_FC_ISCR2_2 0x10B0
#define HDMI_FC_ISCR2_1 0x10B1
#define HDMI_FC_ISCR2_0 0x10B2
#define HDMI_FC_DATAUTO0 0x10B3
#define HDMI_FC_DATAUTO1 0x10B4
#define HDMI_FC_DATAUTO2 0x10B5
#define HDMI_FC_DATMAN 0x10B6
#define HDMI_FC_DATAUTO3 0x10B7
#define HDMI_FC_RDRB0 0x10B8
#define HDMI_FC_RDRB1 0x10B9
#define HDMI_FC_RDRB2 0x10BA
#define HDMI_FC_RDRB3 0x10BB
#define HDMI_FC_RDRB4 0x10BC
#define HDMI_FC_RDRB5 0x10BD
#define HDMI_FC_RDRB6 0x10BE
#define HDMI_FC_RDRB7 0x10BF
#define HDMI_FC_STAT0 0x10D0
#define HDMI_FC_INT0 0x10D1
#define HDMI_FC_MASK0 0x10D2
#define HDMI_FC_POL0 0x10D3
#define HDMI_FC_STAT1 0x10D4
#define HDMI_FC_INT1 0x10D5
#define HDMI_FC_MASK1 0x10D6
#define HDMI_FC_POL1 0x10D7
#define HDMI_FC_STAT2 0x10D8
#define HDMI_FC_INT2 0x10D9
#define HDMI_FC_MASK2 0x10DA
#define HDMI_FC_POL2 0x10DB
#define HDMI_FC_PRCONF 0x10E0
#define HDMI_FC_GMD_STAT 0x1100
#define HDMI_FC_GMD_EN 0x1101
#define HDMI_FC_GMD_UP 0x1102
#define HDMI_FC_GMD_CONF 0x1103
#define HDMI_FC_GMD_HB 0x1104
#define HDMI_FC_GMD_PB0 0x1105
#define HDMI_FC_GMD_PB1 0x1106
#define HDMI_FC_GMD_PB2 0x1107
#define HDMI_FC_GMD_PB3 0x1108
#define HDMI_FC_GMD_PB4 0x1109
#define HDMI_FC_GMD_PB5 0x110A
#define HDMI_FC_GMD_PB6 0x110B
#define HDMI_FC_GMD_PB7 0x110C
#define HDMI_FC_GMD_PB8 0x110D
#define HDMI_FC_GMD_PB9 0x110E
#define HDMI_FC_GMD_PB10 0x110F
#define HDMI_FC_GMD_PB11 0x1110
#define HDMI_FC_GMD_PB12 0x1111
#define HDMI_FC_GMD_PB13 0x1112
#define HDMI_FC_GMD_PB14 0x1113
#define HDMI_FC_GMD_PB15 0x1114
#define HDMI_FC_GMD_PB16 0x1115
#define HDMI_FC_GMD_PB17 0x1116
#define HDMI_FC_GMD_PB18 0x1117
#define HDMI_FC_GMD_PB19 0x1118
#define HDMI_FC_GMD_PB20 0x1119
#define HDMI_FC_GMD_PB21 0x111A
#define HDMI_FC_GMD_PB22 0x111B
#define HDMI_FC_GMD_PB23 0x111C
#define HDMI_FC_GMD_PB24 0x111D
#define HDMI_FC_GMD_PB25 0x111E
#define HDMI_FC_GMD_PB26 0x111F
#define HDMI_FC_GMD_PB27 0x1120
#define HDMI_FC_DBGFORCE 0x1200
#define HDMI_FC_DBGAUD0CH0 0x1201
#define HDMI_FC_DBGAUD1CH0 0x1202
#define HDMI_FC_DBGAUD2CH0 0x1203
#define HDMI_FC_DBGAUD0CH1 0x1204
#define HDMI_FC_DBGAUD1CH1 0x1205
#define HDMI_FC_DBGAUD2CH1 0x1206
#define HDMI_FC_DBGAUD0CH2 0x1207
#define HDMI_FC_DBGAUD1CH2 0x1208
#define HDMI_FC_DBGAUD2CH2 0x1209
#define HDMI_FC_DBGAUD0CH3 0x120A
#define HDMI_FC_DBGAUD1CH3 0x120B
#define HDMI_FC_DBGAUD2CH3 0x120C
#define HDMI_FC_DBGAUD0CH4 0x120D
#define HDMI_FC_DBGAUD1CH4 0x120E
#define HDMI_FC_DBGAUD2CH4 0x120F
#define HDMI_FC_DBGAUD0CH5 0x1210
#define HDMI_FC_DBGAUD1CH5 0x1211
#define HDMI_FC_DBGAUD2CH5 0x1212
#define HDMI_FC_DBGAUD0CH6 0x1213
#define HDMI_FC_DBGAUD1CH6 0x1214
#define HDMI_FC_DBGAUD2CH6 0x1215
#define HDMI_FC_DBGAUD0CH7 0x1216
#define HDMI_FC_DBGAUD1CH7 0x1217
#define HDMI_FC_DBGAUD2CH7 0x1218
#define HDMI_FC_DBGTMDS0 0x1219
#define HDMI_FC_DBGTMDS1 0x121A
#define HDMI_FC_DBGTMDS2 0x121B
/* HDMI Source PHY Registers */
#define HDMI_PHY_CONF0 0x3000
#define HDMI_PHY_TST0 0x3001
#define HDMI_PHY_TST1 0x3002
#define HDMI_PHY_TST2 0x3003
#define HDMI_PHY_STAT0 0x3004
#define HDMI_PHY_INT0 0x3005
#define HDMI_PHY_MASK0 0x3006
#define HDMI_PHY_POL0 0x3007
/* HDMI Master PHY Registers */
#define HDMI_PHY_I2CM_SLAVE_ADDR 0x3020
#define HDMI_PHY_I2CM_ADDRESS_ADDR 0x3021
#define HDMI_PHY_I2CM_DATAO_1_ADDR 0x3022
#define HDMI_PHY_I2CM_DATAO_0_ADDR 0x3023
#define HDMI_PHY_I2CM_DATAI_1_ADDR 0x3024
#define HDMI_PHY_I2CM_DATAI_0_ADDR 0x3025
#define HDMI_PHY_I2CM_OPERATION_ADDR 0x3026
#define HDMI_PHY_I2CM_INT_ADDR 0x3027
#define HDMI_PHY_I2CM_CTLINT_ADDR 0x3028
#define HDMI_PHY_I2CM_DIV_ADDR 0x3029
#define HDMI_PHY_I2CM_SOFTRSTZ_ADDR 0x302a
#define HDMI_PHY_I2CM_SS_SCL_HCNT_1_ADDR 0x302b
#define HDMI_PHY_I2CM_SS_SCL_HCNT_0_ADDR 0x302c
#define HDMI_PHY_I2CM_SS_SCL_LCNT_1_ADDR 0x302d
#define HDMI_PHY_I2CM_SS_SCL_LCNT_0_ADDR 0x302e
#define HDMI_PHY_I2CM_FS_SCL_HCNT_1_ADDR 0x302f
#define HDMI_PHY_I2CM_FS_SCL_HCNT_0_ADDR 0x3030
#define HDMI_PHY_I2CM_FS_SCL_LCNT_1_ADDR 0x3031
#define HDMI_PHY_I2CM_FS_SCL_LCNT_0_ADDR 0x3032
/* Audio Sampler Registers */
#define HDMI_AUD_CONF0 0x3100
#define HDMI_AUD_CONF1 0x3101
#define HDMI_AUD_INT 0x3102
#define HDMI_AUD_CONF2 0x3103
#define HDMI_AUD_N1 0x3200
#define HDMI_AUD_N2 0x3201
#define HDMI_AUD_N3 0x3202
#define HDMI_AUD_CTS1 0x3203
#define HDMI_AUD_CTS2 0x3204
#define HDMI_AUD_CTS3 0x3205
#define HDMI_AUD_INPUTCLKFS 0x3206
#define HDMI_AUD_SPDIFINT 0x3302
#define HDMI_AUD_CONF0_HBR 0x3400
#define HDMI_AUD_HBR_STATUS 0x3401
#define HDMI_AUD_HBR_INT 0x3402
#define HDMI_AUD_HBR_POL 0x3403
#define HDMI_AUD_HBR_MASK 0x3404
/* Generic Parallel Audio Interface Registers */
/* Not used as GPAUD interface is not enabled in hw */
#define HDMI_GP_CONF0 0x3500
#define HDMI_GP_CONF1 0x3501
#define HDMI_GP_CONF2 0x3502
#define HDMI_GP_STAT 0x3503
#define HDMI_GP_INT 0x3504
#define HDMI_GP_MASK 0x3505
#define HDMI_GP_POL 0x3506
/* Audio DMA Registers */
#define HDMI_AHB_DMA_CONF0 0x3600
#define HDMI_AHB_DMA_START 0x3601
#define HDMI_AHB_DMA_STOP 0x3602
#define HDMI_AHB_DMA_THRSLD 0x3603
#define HDMI_AHB_DMA_STRADDR0 0x3604
#define HDMI_AHB_DMA_STRADDR1 0x3605
#define HDMI_AHB_DMA_STRADDR2 0x3606
#define HDMI_AHB_DMA_STRADDR3 0x3607
#define HDMI_AHB_DMA_STPADDR0 0x3608
#define HDMI_AHB_DMA_STPADDR1 0x3609
#define HDMI_AHB_DMA_STPADDR2 0x360a
#define HDMI_AHB_DMA_STPADDR3 0x360b
#define HDMI_AHB_DMA_BSTADDR0 0x360c
#define HDMI_AHB_DMA_BSTADDR1 0x360d
#define HDMI_AHB_DMA_BSTADDR2 0x360e
#define HDMI_AHB_DMA_BSTADDR3 0x360f
#define HDMI_AHB_DMA_MBLENGTH0 0x3610
#define HDMI_AHB_DMA_MBLENGTH1 0x3611
#define HDMI_AHB_DMA_STAT 0x3612
#define HDMI_AHB_DMA_INT 0x3613
#define HDMI_AHB_DMA_MASK 0x3614
#define HDMI_AHB_DMA_POL 0x3615
#define HDMI_AHB_DMA_CONF1 0x3616
#define HDMI_AHB_DMA_BUFFSTAT 0x3617
#define HDMI_AHB_DMA_BUFFINT 0x3618
#define HDMI_AHB_DMA_BUFFMASK 0x3619
#define HDMI_AHB_DMA_BUFFPOL 0x361a
/* Main Controller Registers */
#define HDMI_MC_SFRDIV 0x4000
#define HDMI_MC_CLKDIS 0x4001
#define HDMI_MC_SWRSTZ 0x4002
#define HDMI_MC_OPCTRL 0x4003
#define HDMI_MC_FLOWCTRL 0x4004
#define HDMI_MC_PHYRSTZ 0x4005
#define HDMI_MC_LOCKONCLOCK 0x4006
#define HDMI_MC_HEACPHY_RST 0x4007
/* Color Space Converter Registers */
#define HDMI_CSC_CFG 0x4100
#define HDMI_CSC_SCALE 0x4101
#define HDMI_CSC_COEF_A1_MSB 0x4102
#define HDMI_CSC_COEF_A1_LSB 0x4103
#define HDMI_CSC_COEF_A2_MSB 0x4104
#define HDMI_CSC_COEF_A2_LSB 0x4105
#define HDMI_CSC_COEF_A3_MSB 0x4106
#define HDMI_CSC_COEF_A3_LSB 0x4107
#define HDMI_CSC_COEF_A4_MSB 0x4108
#define HDMI_CSC_COEF_A4_LSB 0x4109
#define HDMI_CSC_COEF_B1_MSB 0x410A
#define HDMI_CSC_COEF_B1_LSB 0x410B
#define HDMI_CSC_COEF_B2_MSB 0x410C
#define HDMI_CSC_COEF_B2_LSB 0x410D
#define HDMI_CSC_COEF_B3_MSB 0x410E
#define HDMI_CSC_COEF_B3_LSB 0x410F
#define HDMI_CSC_COEF_B4_MSB 0x4110
#define HDMI_CSC_COEF_B4_LSB 0x4111
#define HDMI_CSC_COEF_C1_MSB 0x4112
#define HDMI_CSC_COEF_C1_LSB 0x4113
#define HDMI_CSC_COEF_C2_MSB 0x4114
#define HDMI_CSC_COEF_C2_LSB 0x4115
#define HDMI_CSC_COEF_C3_MSB 0x4116
#define HDMI_CSC_COEF_C3_LSB 0x4117
#define HDMI_CSC_COEF_C4_MSB 0x4118
#define HDMI_CSC_COEF_C4_LSB 0x4119
/* HDCP Interrupt Registers */
#define HDMI_A_APIINTCLR 0x5006
#define HDMI_A_APIINTSTAT 0x5007
#define HDMI_A_APIINTMSK 0x5008
/* CEC Engine Registers */
#define HDMI_CEC_CTRL 0x7D00
#define HDMI_CEC_STAT 0x7D01
#define HDMI_CEC_MASK 0x7D02
#define HDMI_CEC_POLARITY 0x7D03
#define HDMI_CEC_INT 0x7D04
#define HDMI_CEC_ADDR_L 0x7D05
#define HDMI_CEC_ADDR_H 0x7D06
#define HDMI_CEC_TX_CNT 0x7D07
#define HDMI_CEC_RX_CNT 0x7D08
#define HDMI_CEC_TX_DATA0 0x7D10
#define HDMI_CEC_TX_DATA1 0x7D11
#define HDMI_CEC_TX_DATA2 0x7D12
#define HDMI_CEC_TX_DATA3 0x7D13
#define HDMI_CEC_TX_DATA4 0x7D14
#define HDMI_CEC_TX_DATA5 0x7D15
#define HDMI_CEC_TX_DATA6 0x7D16
#define HDMI_CEC_TX_DATA7 0x7D17
#define HDMI_CEC_TX_DATA8 0x7D18
#define HDMI_CEC_TX_DATA9 0x7D19
#define HDMI_CEC_TX_DATA10 0x7D1a
#define HDMI_CEC_TX_DATA11 0x7D1b
#define HDMI_CEC_TX_DATA12 0x7D1c
#define HDMI_CEC_TX_DATA13 0x7D1d
#define HDMI_CEC_TX_DATA14 0x7D1e
#define HDMI_CEC_TX_DATA15 0x7D1f
#define HDMI_CEC_RX_DATA0 0x7D20
#define HDMI_CEC_RX_DATA1 0x7D21
#define HDMI_CEC_RX_DATA2 0x7D22
#define HDMI_CEC_RX_DATA3 0x7D23
#define HDMI_CEC_RX_DATA4 0x7D24
#define HDMI_CEC_RX_DATA5 0x7D25
#define HDMI_CEC_RX_DATA6 0x7D26
#define HDMI_CEC_RX_DATA7 0x7D27
#define HDMI_CEC_RX_DATA8 0x7D28
#define HDMI_CEC_RX_DATA9 0x7D29
#define HDMI_CEC_RX_DATA10 0x7D2a
#define HDMI_CEC_RX_DATA11 0x7D2b
#define HDMI_CEC_RX_DATA12 0x7D2c
#define HDMI_CEC_RX_DATA13 0x7D2d
#define HDMI_CEC_RX_DATA14 0x7D2e
#define HDMI_CEC_RX_DATA15 0x7D2f
#define HDMI_CEC_LOCK 0x7D30
#define HDMI_CEC_WKUPCTRL 0x7D31
/* I2C Master Registers (E-DDC) */
#define HDMI_I2CM_SLAVE 0x7E00
#define HDMI_I2CM_ADDRESS 0x7E01
#define HDMI_I2CM_DATAO 0x7E02
#define HDMI_I2CM_DATAI 0x7E03
#define HDMI_I2CM_OPERATION 0x7E04
#define HDMI_I2CM_INT 0x7E05
#define HDMI_I2CM_CTLINT 0x7E06
#define HDMI_I2CM_DIV 0x7E07
#define HDMI_I2CM_SEGADDR 0x7E08
#define HDMI_I2CM_SOFTRSTZ 0x7E09
#define HDMI_I2CM_SEGPTR 0x7E0A
#define HDMI_I2CM_SS_SCL_HCNT_1_ADDR 0x7E0B
#define HDMI_I2CM_SS_SCL_HCNT_0_ADDR 0x7E0C
#define HDMI_I2CM_SS_SCL_LCNT_1_ADDR 0x7E0D
#define HDMI_I2CM_SS_SCL_LCNT_0_ADDR 0x7E0E
#define HDMI_I2CM_FS_SCL_HCNT_1_ADDR 0x7E0F
#define HDMI_I2CM_FS_SCL_HCNT_0_ADDR 0x7E10
#define HDMI_I2CM_FS_SCL_LCNT_1_ADDR 0x7E11
#define HDMI_I2CM_FS_SCL_LCNT_0_ADDR 0x7E12
/* Random Number Generator Registers (RNG) */
#define HDMI_RNG_BASE 0x8000
/*
* Register field definitions
*/
enum {
/* IH_FC_INT2 field values */
HDMI_IH_FC_INT2_OVERFLOW_MASK = 0x03,
HDMI_IH_FC_INT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_IH_FC_INT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* IH_FC_STAT2 field values */
HDMI_IH_FC_STAT2_OVERFLOW_MASK = 0x03,
HDMI_IH_FC_STAT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_IH_FC_STAT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* IH_PHY_STAT0 field values */
HDMI_IH_PHY_STAT0_RX_SENSE3 = 0x20,
HDMI_IH_PHY_STAT0_RX_SENSE2 = 0x10,
HDMI_IH_PHY_STAT0_RX_SENSE1 = 0x8,
HDMI_IH_PHY_STAT0_RX_SENSE0 = 0x4,
HDMI_IH_PHY_STAT0_TX_PHY_LOCK = 0x2,
HDMI_IH_PHY_STAT0_HPD = 0x1,
/* IH_CEC_STAT0 field values */
HDMI_IH_CEC_STAT0_WAKEUP = 0x40,
HDMI_IH_CEC_STAT0_ERROR_FOLL = 0x20,
HDMI_IH_CEC_STAT0_ERROR_INIT = 0x10,
HDMI_IH_CEC_STAT0_ARB_LOST = 0x8,
HDMI_IH_CEC_STAT0_NACK = 0x4,
HDMI_IH_CEC_STAT0_EOM = 0x2,
HDMI_IH_CEC_STAT0_DONE = 0x1,
/* IH_MUTE_I2CMPHY_STAT0 field values */
HDMI_IH_MUTE_I2CMPHY_STAT0_I2CMPHYDONE = 0x2,
HDMI_IH_MUTE_I2CMPHY_STAT0_I2CMPHYERROR = 0x1,
/* IH_PHY_STAT0 field values */
HDMI_IH_MUTE_PHY_STAT0_RX_SENSE3 = 0x20,
HDMI_IH_MUTE_PHY_STAT0_RX_SENSE2 = 0x10,
HDMI_IH_MUTE_PHY_STAT0_RX_SENSE1 = 0x8,
HDMI_IH_MUTE_PHY_STAT0_RX_SENSE0 = 0x4,
HDMI_IH_MUTE_PHY_STAT0_TX_PHY_LOCK = 0x2,
HDMI_IH_MUTE_PHY_STAT0_HPD = 0x1,
/* IH and IH_MUTE convenience macro RX_SENSE | HPD*/
HDMI_DVI_IH_STAT = 0x3D,
/* IH_AHBDMAAUD_STAT0 field values */
HDMI_IH_AHBDMAAUD_STAT0_ERROR = 0x20,
HDMI_IH_AHBDMAAUD_STAT0_LOST = 0x10,
HDMI_IH_AHBDMAAUD_STAT0_RETRY = 0x08,
HDMI_IH_AHBDMAAUD_STAT0_DONE = 0x04,
HDMI_IH_AHBDMAAUD_STAT0_BUFFFULL = 0x02,
HDMI_IH_AHBDMAAUD_STAT0_BUFFEMPTY = 0x01,
/* IH_MUTE_FC_STAT2 field values */
HDMI_IH_MUTE_FC_STAT2_OVERFLOW_MASK = 0x03,
HDMI_IH_MUTE_FC_STAT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_IH_MUTE_FC_STAT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* IH_MUTE_AHBDMAAUD_STAT0 field values */
HDMI_IH_MUTE_AHBDMAAUD_STAT0_ERROR = 0x20,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_LOST = 0x10,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_RETRY = 0x08,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_DONE = 0x04,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_BUFFFULL = 0x02,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_BUFFEMPTY = 0x01,
/* IH_MUTE field values */
HDMI_IH_MUTE_MUTE_WAKEUP_INTERRUPT = 0x2,
HDMI_IH_MUTE_MUTE_ALL_INTERRUPT = 0x1,
/* TX_INVID0 field values */
HDMI_TX_INVID0_INTERNAL_DE_GENERATOR_MASK = 0x80,
HDMI_TX_INVID0_INTERNAL_DE_GENERATOR_ENABLE = 0x80,
HDMI_TX_INVID0_INTERNAL_DE_GENERATOR_DISABLE = 0x00,
HDMI_TX_INVID0_VIDEO_MAPPING_MASK = 0x1F,
HDMI_TX_INVID0_VIDEO_MAPPING_OFFSET = 0,
/* TX_INSTUFFING field values */
HDMI_TX_INSTUFFING_BDBDATA_STUFFING_MASK = 0x4,
HDMI_TX_INSTUFFING_BDBDATA_STUFFING_ENABLE = 0x4,
HDMI_TX_INSTUFFING_BDBDATA_STUFFING_DISABLE = 0x0,
HDMI_TX_INSTUFFING_RCRDATA_STUFFING_MASK = 0x2,
HDMI_TX_INSTUFFING_RCRDATA_STUFFING_ENABLE = 0x2,
HDMI_TX_INSTUFFING_RCRDATA_STUFFING_DISABLE = 0x0,
HDMI_TX_INSTUFFING_GYDATA_STUFFING_MASK = 0x1,
HDMI_TX_INSTUFFING_GYDATA_STUFFING_ENABLE = 0x1,
HDMI_TX_INSTUFFING_GYDATA_STUFFING_DISABLE = 0x0,
/* VP_PR_CD field values */
HDMI_VP_PR_CD_COLOR_DEPTH_MASK = 0xF0,
HDMI_VP_PR_CD_COLOR_DEPTH_OFFSET = 4,
HDMI_VP_PR_CD_DESIRED_PR_FACTOR_MASK = 0x0F,
HDMI_VP_PR_CD_DESIRED_PR_FACTOR_OFFSET = 0,
/* VP_STUFF field values */
HDMI_VP_STUFF_IDEFAULT_PHASE_MASK = 0x20,
HDMI_VP_STUFF_IDEFAULT_PHASE_OFFSET = 5,
HDMI_VP_STUFF_IFIX_PP_TO_LAST_MASK = 0x10,
HDMI_VP_STUFF_IFIX_PP_TO_LAST_OFFSET = 4,
HDMI_VP_STUFF_ICX_GOTO_P0_ST_MASK = 0x8,
HDMI_VP_STUFF_ICX_GOTO_P0_ST_OFFSET = 3,
HDMI_VP_STUFF_YCC422_STUFFING_MASK = 0x4,
HDMI_VP_STUFF_YCC422_STUFFING_STUFFING_MODE = 0x4,
HDMI_VP_STUFF_YCC422_STUFFING_DIRECT_MODE = 0x0,
HDMI_VP_STUFF_PP_STUFFING_MASK = 0x2,
HDMI_VP_STUFF_PP_STUFFING_STUFFING_MODE = 0x2,
HDMI_VP_STUFF_PP_STUFFING_DIRECT_MODE = 0x0,
HDMI_VP_STUFF_PR_STUFFING_MASK = 0x1,
HDMI_VP_STUFF_PR_STUFFING_STUFFING_MODE = 0x1,
HDMI_VP_STUFF_PR_STUFFING_DIRECT_MODE = 0x0,
/* VP_CONF field values */
HDMI_VP_CONF_BYPASS_EN_MASK = 0x40,
HDMI_VP_CONF_BYPASS_EN_ENABLE = 0x40,
HDMI_VP_CONF_BYPASS_EN_DISABLE = 0x00,
HDMI_VP_CONF_PP_EN_ENMASK = 0x20,
HDMI_VP_CONF_PP_EN_ENABLE = 0x20,
HDMI_VP_CONF_PP_EN_DISABLE = 0x00,
HDMI_VP_CONF_PR_EN_MASK = 0x10,
HDMI_VP_CONF_PR_EN_ENABLE = 0x10,
HDMI_VP_CONF_PR_EN_DISABLE = 0x00,
HDMI_VP_CONF_YCC422_EN_MASK = 0x8,
HDMI_VP_CONF_YCC422_EN_ENABLE = 0x8,
HDMI_VP_CONF_YCC422_EN_DISABLE = 0x0,
HDMI_VP_CONF_BYPASS_SELECT_MASK = 0x4,
HDMI_VP_CONF_BYPASS_SELECT_VID_PACKETIZER = 0x4,
HDMI_VP_CONF_BYPASS_SELECT_PIX_REPEATER = 0x0,
HDMI_VP_CONF_OUTPUT_SELECTOR_MASK = 0x3,
HDMI_VP_CONF_OUTPUT_SELECTOR_BYPASS = 0x3,
HDMI_VP_CONF_OUTPUT_SELECTOR_YCC422 = 0x1,
HDMI_VP_CONF_OUTPUT_SELECTOR_PP = 0x0,
/* VP_REMAP field values */
HDMI_VP_REMAP_MASK = 0x3,
HDMI_VP_REMAP_YCC422_24bit = 0x2,
HDMI_VP_REMAP_YCC422_20bit = 0x1,
HDMI_VP_REMAP_YCC422_16bit = 0x0,
/* FC_INVIDCONF field values */
HDMI_FC_INVIDCONF_VSYNC_IN_POLARITY_MASK = 0x40,
HDMI_FC_INVIDCONF_VSYNC_IN_POLARITY_ACTIVE_HIGH = 0x40,
HDMI_FC_INVIDCONF_VSYNC_IN_POLARITY_ACTIVE_LOW = 0x00,
HDMI_FC_INVIDCONF_HSYNC_IN_POLARITY_MASK = 0x20,
HDMI_FC_INVIDCONF_HSYNC_IN_POLARITY_ACTIVE_HIGH = 0x20,
HDMI_FC_INVIDCONF_HSYNC_IN_POLARITY_ACTIVE_LOW = 0x00,
HDMI_FC_INVIDCONF_DE_IN_POLARITY_MASK = 0x10,
HDMI_FC_INVIDCONF_DE_IN_POLARITY_ACTIVE_HIGH = 0x10,
HDMI_FC_INVIDCONF_DE_IN_POLARITY_ACTIVE_LOW = 0x00,
HDMI_FC_INVIDCONF_DVI_MODEZ_MASK = 0x8,
HDMI_FC_INVIDCONF_DVI_MODEZ_HDMI_MODE = 0x8,
HDMI_FC_INVIDCONF_DVI_MODEZ_DVI_MODE = 0x0,
HDMI_FC_INVIDCONF_R_V_BLANK_IN_OSC_MASK = 0x2,
HDMI_FC_INVIDCONF_R_V_BLANK_IN_OSC_ACTIVE_HIGH = 0x2,
HDMI_FC_INVIDCONF_R_V_BLANK_IN_OSC_ACTIVE_LOW = 0x0,
HDMI_FC_INVIDCONF_IN_I_P_MASK = 0x1,
HDMI_FC_INVIDCONF_IN_I_P_INTERLACED = 0x1,
HDMI_FC_INVIDCONF_IN_I_P_PROGRESSIVE = 0x0,
/* FC_AUDICONF0 field values */
HDMI_FC_AUDICONF0_CC_OFFSET = 4,
HDMI_FC_AUDICONF0_CC_MASK = 0x70,
HDMI_FC_AUDICONF0_CT_OFFSET = 0,
HDMI_FC_AUDICONF0_CT_MASK = 0xF,
/* FC_AUDICONF1 field values */
HDMI_FC_AUDICONF1_SS_OFFSET = 3,
HDMI_FC_AUDICONF1_SS_MASK = 0x18,
HDMI_FC_AUDICONF1_SF_OFFSET = 0,
HDMI_FC_AUDICONF1_SF_MASK = 0x7,
/* FC_AUDICONF3 field values */
HDMI_FC_AUDICONF3_LFEPBL_OFFSET = 5,
HDMI_FC_AUDICONF3_LFEPBL_MASK = 0x60,
HDMI_FC_AUDICONF3_DM_INH_OFFSET = 4,
HDMI_FC_AUDICONF3_DM_INH_MASK = 0x10,
HDMI_FC_AUDICONF3_LSV_OFFSET = 0,
HDMI_FC_AUDICONF3_LSV_MASK = 0xF,
/* FC_AUDSCHNLS0 field values */
HDMI_FC_AUDSCHNLS0_CGMSA_OFFSET = 4,
HDMI_FC_AUDSCHNLS0_CGMSA_MASK = 0x30,
HDMI_FC_AUDSCHNLS0_COPYRIGHT_OFFSET = 0,
HDMI_FC_AUDSCHNLS0_COPYRIGHT_MASK = 0x01,
/* FC_AUDSCHNLS3-6 field values */
HDMI_FC_AUDSCHNLS3_OIEC_CH0_OFFSET = 0,
HDMI_FC_AUDSCHNLS3_OIEC_CH0_MASK = 0x0f,
HDMI_FC_AUDSCHNLS3_OIEC_CH1_OFFSET = 4,
HDMI_FC_AUDSCHNLS3_OIEC_CH1_MASK = 0xf0,
HDMI_FC_AUDSCHNLS4_OIEC_CH2_OFFSET = 0,
HDMI_FC_AUDSCHNLS4_OIEC_CH2_MASK = 0x0f,
HDMI_FC_AUDSCHNLS4_OIEC_CH3_OFFSET = 4,
HDMI_FC_AUDSCHNLS4_OIEC_CH3_MASK = 0xf0,
HDMI_FC_AUDSCHNLS5_OIEC_CH0_OFFSET = 0,
HDMI_FC_AUDSCHNLS5_OIEC_CH0_MASK = 0x0f,
HDMI_FC_AUDSCHNLS5_OIEC_CH1_OFFSET = 4,
HDMI_FC_AUDSCHNLS5_OIEC_CH1_MASK = 0xf0,
HDMI_FC_AUDSCHNLS6_OIEC_CH2_OFFSET = 0,
HDMI_FC_AUDSCHNLS6_OIEC_CH2_MASK = 0x0f,
HDMI_FC_AUDSCHNLS6_OIEC_CH3_OFFSET = 4,
HDMI_FC_AUDSCHNLS6_OIEC_CH3_MASK = 0xf0,
/* HDMI_FC_AUDSCHNLS7 field values */
HDMI_FC_AUDSCHNLS7_ACCURACY_OFFSET = 4,
HDMI_FC_AUDSCHNLS7_ACCURACY_MASK = 0x30,
/* HDMI_FC_AUDSCHNLS8 field values */
HDMI_FC_AUDSCHNLS8_ORIGSAMPFREQ_MASK = 0xf0,
HDMI_FC_AUDSCHNLS8_ORIGSAMPFREQ_OFFSET = 4,
HDMI_FC_AUDSCHNLS8_WORDLEGNTH_MASK = 0x0f,
HDMI_FC_AUDSCHNLS8_WORDLEGNTH_OFFSET = 0,
/* FC_AUDSCONF field values */
HDMI_FC_AUDSCONF_AUD_PACKET_SAMPFIT_MASK = 0xF0,
HDMI_FC_AUDSCONF_AUD_PACKET_SAMPFIT_OFFSET = 4,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_MASK = 0x1,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_OFFSET = 0,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_LAYOUT1 = 0x1,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_LAYOUT0 = 0x0,
/* FC_STAT2 field values */
HDMI_FC_STAT2_OVERFLOW_MASK = 0x03,
HDMI_FC_STAT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_FC_STAT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* FC_INT2 field values */
HDMI_FC_INT2_OVERFLOW_MASK = 0x03,
HDMI_FC_INT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_FC_INT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* FC_MASK2 field values */
HDMI_FC_MASK2_OVERFLOW_MASK = 0x03,
HDMI_FC_MASK2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_FC_MASK2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* FC_PRCONF field values */
HDMI_FC_PRCONF_INCOMING_PR_FACTOR_MASK = 0xF0,
HDMI_FC_PRCONF_INCOMING_PR_FACTOR_OFFSET = 4,
HDMI_FC_PRCONF_OUTPUT_PR_FACTOR_MASK = 0x0F,
HDMI_FC_PRCONF_OUTPUT_PR_FACTOR_OFFSET = 0,
/* FC_AVICONF0-FC_AVICONF3 field values */
HDMI_FC_AVICONF0_PIX_FMT_MASK = 0x03,
HDMI_FC_AVICONF0_PIX_FMT_RGB = 0x00,
HDMI_FC_AVICONF0_PIX_FMT_YCBCR422 = 0x01,
HDMI_FC_AVICONF0_PIX_FMT_YCBCR444 = 0x02,
HDMI_FC_AVICONF0_ACTIVE_FMT_MASK = 0x40,
HDMI_FC_AVICONF0_ACTIVE_FMT_INFO_PRESENT = 0x40,
HDMI_FC_AVICONF0_ACTIVE_FMT_NO_INFO = 0x00,
HDMI_FC_AVICONF0_BAR_DATA_MASK = 0x0C,
HDMI_FC_AVICONF0_BAR_DATA_NO_DATA = 0x00,
HDMI_FC_AVICONF0_BAR_DATA_VERT_BAR = 0x04,
HDMI_FC_AVICONF0_BAR_DATA_HORIZ_BAR = 0x08,
HDMI_FC_AVICONF0_BAR_DATA_VERT_HORIZ_BAR = 0x0C,
HDMI_FC_AVICONF0_SCAN_INFO_MASK = 0x30,
HDMI_FC_AVICONF0_SCAN_INFO_OVERSCAN = 0x10,
HDMI_FC_AVICONF0_SCAN_INFO_UNDERSCAN = 0x20,
HDMI_FC_AVICONF0_SCAN_INFO_NODATA = 0x00,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_MASK = 0x0F,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_USE_CODED = 0x08,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_4_3 = 0x09,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_16_9 = 0x0A,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_14_9 = 0x0B,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_MASK = 0x30,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_NO_DATA = 0x00,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_4_3 = 0x10,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_16_9 = 0x20,
HDMI_FC_AVICONF1_COLORIMETRY_MASK = 0xC0,
HDMI_FC_AVICONF1_COLORIMETRY_NO_DATA = 0x00,
HDMI_FC_AVICONF1_COLORIMETRY_SMPTE = 0x40,
HDMI_FC_AVICONF1_COLORIMETRY_ITUR = 0x80,
HDMI_FC_AVICONF1_COLORIMETRY_EXTENDED_INFO = 0xC0,
HDMI_FC_AVICONF2_SCALING_MASK = 0x03,
HDMI_FC_AVICONF2_SCALING_NONE = 0x00,
HDMI_FC_AVICONF2_SCALING_HORIZ = 0x01,
HDMI_FC_AVICONF2_SCALING_VERT = 0x02,
HDMI_FC_AVICONF2_SCALING_HORIZ_VERT = 0x03,
HDMI_FC_AVICONF2_RGB_QUANT_MASK = 0x0C,
HDMI_FC_AVICONF2_RGB_QUANT_DEFAULT = 0x00,
HDMI_FC_AVICONF2_RGB_QUANT_LIMITED_RANGE = 0x04,
HDMI_FC_AVICONF2_RGB_QUANT_FULL_RANGE = 0x08,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_MASK = 0x70,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_XVYCC601 = 0x00,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_XVYCC709 = 0x10,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_SYCC601 = 0x20,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_ADOBE_YCC601 = 0x30,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_ADOBE_RGB = 0x40,
HDMI_FC_AVICONF2_IT_CONTENT_MASK = 0x80,
HDMI_FC_AVICONF2_IT_CONTENT_NO_DATA = 0x00,
HDMI_FC_AVICONF2_IT_CONTENT_VALID = 0x80,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_MASK = 0x03,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_GRAPHICS = 0x00,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_PHOTO = 0x01,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_CINEMA = 0x02,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_GAME = 0x03,
HDMI_FC_AVICONF3_QUANT_RANGE_MASK = 0x0C,
HDMI_FC_AVICONF3_QUANT_RANGE_LIMITED = 0x00,
HDMI_FC_AVICONF3_QUANT_RANGE_FULL = 0x04,
/* FC_DBGFORCE field values */
HDMI_FC_DBGFORCE_FORCEAUDIO = 0x10,
HDMI_FC_DBGFORCE_FORCEVIDEO = 0x1,
/* PHY_CONF0 field values */
HDMI_PHY_CONF0_PDZ_MASK = 0x80,
HDMI_PHY_CONF0_PDZ_OFFSET = 7,
HDMI_PHY_CONF0_ENTMDS_MASK = 0x40,
HDMI_PHY_CONF0_ENTMDS_OFFSET = 6,
HDMI_PHY_CONF0_SPARECTRL = 0x20,
HDMI_PHY_CONF0_GEN2_PDDQ_MASK = 0x10,
HDMI_PHY_CONF0_GEN2_PDDQ_OFFSET = 4,
HDMI_PHY_CONF0_GEN2_TXPWRON_MASK = 0x8,
HDMI_PHY_CONF0_GEN2_TXPWRON_OFFSET = 3,
HDMI_PHY_CONF0_GEN2_ENHPDRXSENSE_MASK = 0x4,
HDMI_PHY_CONF0_GEN2_ENHPDRXSENSE_OFFSET = 2,
HDMI_PHY_CONF0_SELDATAENPOL_MASK = 0x2,
HDMI_PHY_CONF0_SELDATAENPOL_OFFSET = 1,
HDMI_PHY_CONF0_SELDIPIF_MASK = 0x1,
HDMI_PHY_CONF0_SELDIPIF_OFFSET = 0,
/* PHY_TST0 field values */
HDMI_PHY_TST0_TSTCLR_MASK = 0x20,
HDMI_PHY_TST0_TSTCLR_OFFSET = 5,
HDMI_PHY_TST0_TSTEN_MASK = 0x10,
HDMI_PHY_TST0_TSTEN_OFFSET = 4,
HDMI_PHY_TST0_TSTCLK_MASK = 0x1,
HDMI_PHY_TST0_TSTCLK_OFFSET = 0,
/* PHY_STAT0 field values */
HDMI_PHY_RX_SENSE3 = 0x80,
HDMI_PHY_RX_SENSE2 = 0x40,
HDMI_PHY_RX_SENSE1 = 0x20,
HDMI_PHY_RX_SENSE0 = 0x10,
HDMI_PHY_HPD = 0x02,
HDMI_PHY_TX_PHY_LOCK = 0x01,
/* HDMI STAT convenience RX_SENSE | HPD */
HDMI_DVI_STAT = 0xF2,
/* PHY_I2CM_SLAVE_ADDR field values */
HDMI_PHY_I2CM_SLAVE_ADDR_PHY_GEN2 = 0x69,
HDMI_PHY_I2CM_SLAVE_ADDR_HEAC_PHY = 0x49,
/* PHY_I2CM_OPERATION_ADDR field values */
HDMI_PHY_I2CM_OPERATION_ADDR_WRITE = 0x10,
HDMI_PHY_I2CM_OPERATION_ADDR_READ = 0x1,
/* HDMI_PHY_I2CM_INT_ADDR */
HDMI_PHY_I2CM_INT_ADDR_DONE_POL = 0x08,
HDMI_PHY_I2CM_INT_ADDR_DONE_MASK = 0x04,
/* HDMI_PHY_I2CM_CTLINT_ADDR */
HDMI_PHY_I2CM_CTLINT_ADDR_NAC_POL = 0x80,
HDMI_PHY_I2CM_CTLINT_ADDR_NAC_MASK = 0x40,
HDMI_PHY_I2CM_CTLINT_ADDR_ARBITRATION_POL = 0x08,
HDMI_PHY_I2CM_CTLINT_ADDR_ARBITRATION_MASK = 0x04,
/* AUD_CTS3 field values */
HDMI_AUD_CTS3_N_SHIFT_OFFSET = 5,
HDMI_AUD_CTS3_N_SHIFT_MASK = 0xe0,
HDMI_AUD_CTS3_N_SHIFT_1 = 0,
HDMI_AUD_CTS3_N_SHIFT_16 = 0x20,
HDMI_AUD_CTS3_N_SHIFT_32 = 0x40,
HDMI_AUD_CTS3_N_SHIFT_64 = 0x60,
HDMI_AUD_CTS3_N_SHIFT_128 = 0x80,
HDMI_AUD_CTS3_N_SHIFT_256 = 0xa0,
/* note that the CTS3 MANUAL bit has been removed
from our part. Can't set it, will read as 0. */
HDMI_AUD_CTS3_CTS_MANUAL = 0x10,
HDMI_AUD_CTS3_AUDCTS19_16_MASK = 0x0f,
/* AHB_DMA_CONF0 field values */
HDMI_AHB_DMA_CONF0_SW_FIFO_RST_OFFSET = 7,
HDMI_AHB_DMA_CONF0_SW_FIFO_RST_MASK = 0x80,
HDMI_AHB_DMA_CONF0_HBR = 0x10,
HDMI_AHB_DMA_CONF0_EN_HLOCK_OFFSET = 3,
HDMI_AHB_DMA_CONF0_EN_HLOCK_MASK = 0x08,
HDMI_AHB_DMA_CONF0_INCR_TYPE_OFFSET = 1,
HDMI_AHB_DMA_CONF0_INCR_TYPE_MASK = 0x06,
HDMI_AHB_DMA_CONF0_INCR4 = 0x0,
HDMI_AHB_DMA_CONF0_INCR8 = 0x2,
HDMI_AHB_DMA_CONF0_INCR16 = 0x4,
HDMI_AHB_DMA_CONF0_BURST_MODE = 0x1,
/* HDMI_AHB_DMA_START field values */
HDMI_AHB_DMA_START_START_OFFSET = 0,
HDMI_AHB_DMA_START_START_MASK = 0x01,
/* HDMI_AHB_DMA_STOP field values */
HDMI_AHB_DMA_STOP_STOP_OFFSET = 0,
HDMI_AHB_DMA_STOP_STOP_MASK = 0x01,
/* AHB_DMA_STAT, AHB_DMA_INT, AHB_DMA_MASK, AHB_DMA_POL field values */
HDMI_AHB_DMA_DONE = 0x80,
HDMI_AHB_DMA_RETRY_SPLIT = 0x40,
HDMI_AHB_DMA_LOSTOWNERSHIP = 0x20,
HDMI_AHB_DMA_ERROR = 0x10,
HDMI_AHB_DMA_FIFO_THREMPTY = 0x04,
HDMI_AHB_DMA_FIFO_FULL = 0x02,
HDMI_AHB_DMA_FIFO_EMPTY = 0x01,
/* AHB_DMA_BUFFSTAT, AHB_DMA_BUFFINT, AHB_DMA_BUFFMASK, AHB_DMA_BUFFPOL field values */
HDMI_AHB_DMA_BUFFSTAT_FULL = 0x02,
HDMI_AHB_DMA_BUFFSTAT_EMPTY = 0x01,
/* MC_CLKDIS field values */
HDMI_MC_CLKDIS_HDCPCLK_DISABLE = 0x40,
HDMI_MC_CLKDIS_CECCLK_DISABLE = 0x20,
HDMI_MC_CLKDIS_CSCCLK_DISABLE = 0x10,
HDMI_MC_CLKDIS_AUDCLK_DISABLE = 0x8,
HDMI_MC_CLKDIS_PREPCLK_DISABLE = 0x4,
HDMI_MC_CLKDIS_TMDSCLK_DISABLE = 0x2,
HDMI_MC_CLKDIS_PIXELCLK_DISABLE = 0x1,
/* MC_SWRSTZ field values */
HDMI_MC_SWRSTZ_TMDSSWRST_REQ = 0x02,
/* MC_FLOWCTRL field values */
HDMI_MC_FLOWCTRL_FEED_THROUGH_OFF_MASK = 0x1,
HDMI_MC_FLOWCTRL_FEED_THROUGH_OFF_CSC_IN_PATH = 0x1,
HDMI_MC_FLOWCTRL_FEED_THROUGH_OFF_CSC_BYPASS = 0x0,
/* MC_PHYRSTZ field values */
HDMI_MC_PHYRSTZ_ASSERT = 0x0,
HDMI_MC_PHYRSTZ_DEASSERT = 0x1,
/* MC_HEACPHY_RST field values */
HDMI_MC_HEACPHY_RST_ASSERT = 0x1,
HDMI_MC_HEACPHY_RST_DEASSERT = 0x0,
/* CSC_CFG field values */
HDMI_CSC_CFG_INTMODE_MASK = 0x30,
HDMI_CSC_CFG_INTMODE_OFFSET = 4,
HDMI_CSC_CFG_INTMODE_DISABLE = 0x00,
HDMI_CSC_CFG_INTMODE_CHROMA_INT_FORMULA1 = 0x10,
HDMI_CSC_CFG_INTMODE_CHROMA_INT_FORMULA2 = 0x20,
HDMI_CSC_CFG_DECMODE_MASK = 0x3,
HDMI_CSC_CFG_DECMODE_OFFSET = 0,
HDMI_CSC_CFG_DECMODE_DISABLE = 0x0,
HDMI_CSC_CFG_DECMODE_CHROMA_INT_FORMULA1 = 0x1,
HDMI_CSC_CFG_DECMODE_CHROMA_INT_FORMULA2 = 0x2,
HDMI_CSC_CFG_DECMODE_CHROMA_INT_FORMULA3 = 0x3,
/* CSC_SCALE field values */
HDMI_CSC_SCALE_CSC_COLORDE_PTH_MASK = 0xF0,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_24BPP = 0x00,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_30BPP = 0x50,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_36BPP = 0x60,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_48BPP = 0x70,
HDMI_CSC_SCALE_CSCSCALE_MASK = 0x03,
/* I2CM_OPERATION field values */
HDMI_I2CM_OPERATION_WRITE = 0x10,
HDMI_I2CM_OPERATION_READ_EXT = 0x2,
HDMI_I2CM_OPERATION_READ = 0x1,
/* HDMI_I2CM_INT */
HDMI_I2CM_INT_DONE_POL = 0x08,
HDMI_I2CM_INT_DONE_MASK = 0x04,
/* HDMI_I2CM_CTLINT */
HDMI_I2CM_CTLINT_NAC_POL = 0x80,
HDMI_I2CM_CTLINT_NAC_MASK = 0x40,
HDMI_I2CM_CTLINT_ARBITRATION_POL = 0x08,
HDMI_I2CM_CTLINT_ARBITRATION_MASK = 0x04,
};
enum imx_hdmi_type {
IMX6DL_HDMI,
IMX6Q_HDMI,
};
/* IOCTL commands */
#define HDMI_IOC_MAGIC 'H'
#define HDMI_IOC_GET_RESOURCE _IO(HDMI_IOC_MAGIC, 0)
#define HDMI_IOC_GET_CPU_TYPE _IO(HDMI_IOC_MAGIC, 1)
#endif /* __MXC_HDMI_H__ */